首頁 > 後端開發 > Python教學 > 如何在 Python FastAPI 中記錄原始 HTTP 請求和回應?

如何在 Python FastAPI 中記錄原始 HTTP 請求和回應?

Susan Sarandon
發布: 2024-11-30 01:01:13
原創
446 人瀏覽過

How to Log Raw HTTP Requests and Responses in Python FastAPI?

如何在 Python FastAPI 中記錄原始 HTTP 請求/回應?

FastAPI 提供了多種方法來擷取和記錄原始 HTTP 請求和回應,滿足特定要求和效能考量。

選項 1:中間件

中間件可讓您攔截和處理請求和回應。您可以建立一個中間件來消耗流中的請求正文並將其儲存。對於回應正文,將其讀入位元組物件並傳回自訂回應。使用 BackgroundTask 非同步記錄數據,以避免影響回應時間。

範例:

async def some_middleware(request: Request, call_next):
    req_body = await request.body()
    response = await call_next(request)
    res_body = b''
    async for chunk in response.body_iterator:
        res_body += chunk
    task = BackgroundTask(log_info, req_body, res_body)
    return Response(content=res_body, background=task)
登入後複製

選項2:自訂APIRoute 類別

建立自訂APIRoute 類別

建立自訂APIRoute 類別

class LoggingRoute(APIRoute):
    async def custom_route_handler(request: Request) -> Response:
        req_body = await request.body()
        response = await original_route_handler(request)
        res_body = b''
        async for item in response.body_iterator:
            res_body += item
        task = BackgroundTask(log_info, req_body, res_body)
        response = Response(content=res_body, background=task)
        return response
登入後複製
建立自訂作業要求API和響應主體。這種方法可讓您將日誌記錄限制為 APIRouter 中定義的特定路由。

範例:考慮在中儲存大型請求/回應正文的限制記憶體並使用BackgroundTask來避免阻塞請求處理。如有必要,將日誌記錄限制為特定路由或排除回傳流回應的端點。

以上是如何在 Python FastAPI 中記錄原始 HTTP 請求和回應?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板