如何自訂FastAPI針對特定路由的錯誤回應?

Mary-Kate Olsen
發布: 2024-11-20 00:35:02
原創
655 人瀏覽過

How to Customize FastAPI's Error Response for Specific Routes?

為FastAPI中的特定路由自訂錯誤回應

在FastAPI中,當驗證要求時,如果參數遺失或無效, FastAPI引發RequestValidationError 異常。預設情況下,此異常會傳回 422 Unprocessable Entity 回應。但是,您可能希望針對特定路由自訂此回應。以下是實現此目的的幾種方法:

選項1:覆蓋預設異常處理程序

覆蓋RequestValidationError 的預設異常處理程序並為所需的內容提供自訂回應路線。

from fastapi import FastAPI, Request, status, HTTPException
from fastapi.responses import JSONResponse
from fastapi.encoders import jsonable_encoder
from fastapi.exceptions import RequestValidationError

app = FastAPI()
routes_with_custom_exception = ['/']

@app.exception_handler(RequestValidationError)
async def validation_exception_handler(request: Request, exc: RequestValidationError):
    if request.url.path in routes_with_custom_exception:
        return JSONResponse(content={'401': 'Unauthorized'}, status_code=401)
登入後複製

選項 2:使用子應用程式

建立一個子應用程式並將其掛載到特定路由的主應用程式。重寫子應用程式中 RequestValidationError 的異常處理程序。

from fastapi import FastAPI, RequestValidationError, HTTPException
from fastapi.responses import JSONResponse

app = FastAPI()
subapi = FastAPI()

@subapi.exception_handler(RequestValidationError)
async def validation_exception_handler(request: Request, exc: RequestValidationError):
    return 
JSONResponse(content={'401': 'Unauthorized'}, status_code=401)

app.mount('/sub', subapi)
登入後複製

選項 3:使用自訂 APIRouter 和 APIRoute

建立自訂 APIRoute 子類別並重寫get_route_handler 方法。這允許您攔截請求並處理 RequestValidationError 異常。

from fastapi import FastAPI
from fastapi.routing import APIRoute
from fastapi.responses import JSONResponse
from fastapi.exceptions import RequestValidationError
from fastapi.requests import Request

class ValidationErrorHandlingRoute(APIRoute):
    def get_route_handler(self):
        original_route_handler = super().get_route_handler()

        async def custom_route_handler(request: Request):
            try:
                return await original_route_handler(request)
            except RequestValidationError as e:
                return JSONResponse(content={'401': 'Unauthorized'}, status_code=401)

        return custom_route_handler

app = FastAPI()
router = APIRouter(route_class=ValidationErrorHandlingRoute)

@app.get('/')
async def main():
    return {'message': 'Hello from main API'}

@router.get('/custom')
async def custom_route(some_custom_header: str = Header(...)):
    return {'some-custom-header': some_custom_header}

app.include_router(router)
登入後複製

以上是如何自訂FastAPI針對特定路由的錯誤回應?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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