Protokollieren roher HTTP-Anfrage-/Antworttexte in Python FastAPI
In Python FastAPI können Sie die rohen JSON-Texte bestimmter Anfragen/Antworten protokollieren Routen durch den Einsatz von Middleware oder benutzerdefinierten APIRoute-Klassen.
Option 1: Verwenden Middleware
Mit Middleware können Sie Anfragen und Antworten bearbeiten, bevor sie von Endpunkten verarbeitet werden. So erstellen Sie Middleware:
@app.middleware("http") async def middleware(request: Request, call_next): # ... return await call_next(request)
Verwenden Sie die Methoden request.body() oder request.stream(), um den Anforderungstext zu nutzen. Speichern Sie den Text in einer Hintergrundaufgabe, um ihn später zu protokollieren.
Verwenden Sie für den Antworttext benutzerdefinierten Code, um ihn zu lesen und zu speichern:
res_body = b'' async for chunk in response.body_iterator: res_body += chunk
Sie können dann sowohl den Anforderungs- als auch den Antworttext darin protokollieren die BackgroundTask, um eine Beeinträchtigung der Antwortzeit zu vermeiden.
Option 2: Benutzerdefinierte APIRoute verwenden Klasse
Erstellen Sie eine benutzerdefinierte APIRoute-Klasse, um Anforderungs- und Antworttexte zu verarbeiten:
class LoggingRoute(APIRoute): # ... async def custom_route_handler(request: Request) -> Response: # ... return response
Verwenden Sie im benutzerdefinierten Route-Handler den Anforderungstext und behandeln Sie den Antworttext ähnlich wie bei Option 1 Mit diesem Ansatz können Sie die Protokollierung auf bestimmte Routen beschränken APIRouter.
Überlegungen
Das obige ist der detaillierte Inhalt vonWie kann ich rohe HTTP-Anforderungs- und Antwortkörper in Python FastAPI protokollieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!