Heim Backend-Entwicklung Python-Tutorial Wie kann ich rohe HTTP-Anforderungs- und Antwortkörper in Python FastAPI protokollieren?

Wie kann ich rohe HTTP-Anforderungs- und Antwortkörper in Python FastAPI protokollieren?

Nov 29, 2024 pm 02:00 PM

How Can I Log Raw HTTP Request and Response Bodies in Python FastAPI?

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)
Nach dem Login kopieren

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
Nach dem Login kopieren

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
Nach dem Login kopieren

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

  • Große Anforderungs-/Antwortkörper (> Server-RAM) können Speicherprobleme verursachen.
  • Streaming-Antworten können auftreten Probleme oder Verzögerungen auf Kundenseite, weil die gesamte Antwort vor der Rücksendung gelesen wird.
  • Berücksichtigen Sie Nutzungsbeschränkungen oder Alternative Protokollierungsstrategien für Endpunkte, die große oder Streaming-Antworten zurückgeben.

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!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße Artikel -Tags

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wie benutze ich eine schöne Suppe, um HTML zu analysieren? Wie benutze ich eine schöne Suppe, um HTML zu analysieren? Mar 10, 2025 pm 06:54 PM

Wie benutze ich eine schöne Suppe, um HTML zu analysieren?

Bildfilterung in Python Bildfilterung in Python Mar 03, 2025 am 09:44 AM

Bildfilterung in Python

So verwenden Sie Python, um die ZiPF -Verteilung einer Textdatei zu finden So verwenden Sie Python, um die ZiPF -Verteilung einer Textdatei zu finden Mar 05, 2025 am 09:58 AM

So verwenden Sie Python, um die ZiPF -Verteilung einer Textdatei zu finden

Wie man mit PDF -Dokumenten mit Python arbeitet Wie man mit PDF -Dokumenten mit Python arbeitet Mar 02, 2025 am 09:54 AM

Wie man mit PDF -Dokumenten mit Python arbeitet

Wie kann man mit Redis in Django -Anwendungen zwischenstrichen Wie kann man mit Redis in Django -Anwendungen zwischenstrichen Mar 02, 2025 am 10:10 AM

Wie kann man mit Redis in Django -Anwendungen zwischenstrichen

Wie führe ich ein tiefes Lernen mit Tensorflow oder Pytorch durch? Wie führe ich ein tiefes Lernen mit Tensorflow oder Pytorch durch? Mar 10, 2025 pm 06:52 PM

Wie führe ich ein tiefes Lernen mit Tensorflow oder Pytorch durch?

Serialisierung und Deserialisierung von Python -Objekten: Teil 1 Serialisierung und Deserialisierung von Python -Objekten: Teil 1 Mar 08, 2025 am 09:39 AM

Serialisierung und Deserialisierung von Python -Objekten: Teil 1

So implementieren Sie Ihre eigene Datenstruktur in Python So implementieren Sie Ihre eigene Datenstruktur in Python Mar 03, 2025 am 09:28 AM

So implementieren Sie Ihre eigene Datenstruktur in Python

See all articles