」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何為特定 FastAPI 路由自訂錯誤回應?

如何為特定 FastAPI 路由自訂錯誤回應?

發佈於2024-12-21
瀏覽:483

How to Customize Error Responses for Specific FastAPI Routes?

如何在 FastAPI 中自訂特定路由的錯誤回應

在 FastAPI 中,引發 RequestValidationError 允許您傳送自訂錯誤回應。這對於需要滿足特定條件的端點非常有用,例如必需的標頭。

選項 1:覆寫預設例外處理程序

此選項可讓您覆寫預設例外處理程序RequestValidationError,讓您自訂錯誤回應。

from fastapi import FastAPI, Request, Header, status
from fastapi.exceptions import RequestValidationError
from fastapi.responses import JSONResponse

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)
    
    return JSONResponse(
        status_code=status.HTTP_422_UNPROCESSABLE_ENTITY,
        content=jsonable_encoder({'detail': exc.errors(), 'body': exc.body}),
    )

選項 2:使用子應用程式

建立子應用程式可讓您建立具有自己的例外處理程序的單獨 API 實例。這允許您專門為子應用程式自訂錯誤處理。

from fastapi import FastAPI
from fastapi.exceptions import RequestValidationError
from fastapi.responses import JSONResponse

app = FastAPI()
subapi = FastAPI()

@subapi.exception_handler(RequestValidationError)
async def validation_exception_handler(exc: RequestValidationError):
    return JSONResponse(content={'401': 'Unauthorized'}, status_code=401)
    
@subapi.get('/')
async def subapi_route(some_custom_header: str = Header(...)):
    return {'some-custom-header': some_custom_header}

app.mount('/sub', subapi)

選項 3:使用自訂 APIRoute 類別

此方法可讓您使用自訂 APIRoute 類別變更特定路由的行為。

from fastapi import FastAPI, APIRouter, Response, Request, Header, HTTPException
from fastapi.exceptions import RequestValidationError

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

        async def custom_route_handler(request: Request) -> Response:
            try:
                return await original_route_handler(request)
            except RequestValidationError as e:
                raise HTTPException(status_code=401, detail='401 Unauthorized')

        return custom_route_handler

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

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

app.include_router(router)

您應該使用哪個選項?

當您只需要為特定路由自訂錯誤回應時,選項 1 很容易實現。當您想要對 API 的子區域進行更多控制(例如套用不同的安全性原則或例外處理)時,選項 2 適合。選項 3 可讓您更好地控制各個路線,並且對於處理路線內的特定情況很有用。

最新教學 更多>
  • 如何使用 JavaScript 轉義 JSON 字串中的換行符號?
    如何使用 JavaScript 轉義 JSON 字串中的換行符號?
    JavaScript 中使用換行符轉義JSON 字符串在JavaScript 中,構造JSON 字符串需要轉義特殊字符,包括換行符。為此,請按照下列步驟操作:1。字串化 JSON 物件:使用 JSON.stringify() 將 JSON 物件轉換為字串。 2.轉義換行符:利用 .replace()...
    程式設計 發佈於2024-12-21
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-12-21
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSocke...
    程式設計 發佈於2024-12-21
  • 為什麼 SimpleDateFormat 錯誤地解析「YYYY-MM-dd HH:mm」?
    為什麼 SimpleDateFormat 錯誤地解析「YYYY-MM-dd HH:mm」?
    SimpleDateFormat 錯誤解析「YYYY-MM-dd HH:mm」試著解析格式為「YYYY-MM」的字串時-dd HH:mm" 到日期,一些開發人員遇到意外的日期結果。當使用SimpleDateFormat 類別並將lenient 設定設為false 時,會發生這種情況。 St...
    程式設計 發佈於2024-12-21
  • HTML 格式標籤
    HTML 格式標籤
    HTML 格式化元素 **HTML Formatting is a process of formatting text for better look and feel. HTML provides us ability to format text without us...
    程式設計 發佈於2024-12-21
  • 如何在Python中高效率計算列表的平均值?
    如何在Python中高效率計算列表的平均值?
    在Python中計算清單的平均值確定清單的算術平均值或平均值對於統計分析至關重要。在 Python 中,有多種方法可用於此操作。以下是對每種方法的詳細探索:Python >= 3.8:statistics.fmean統計模組提供了浮點數的數值穩定性,確保準確的結果。這是Python 3.8及更高版本...
    程式設計 發佈於2024-12-21
  • 如何設計與標準庫正確整合的自訂 STL 容器?
    如何設計與標準庫正確整合的自訂 STL 容器?
    編寫自訂STL 容器的指南設計符合STL 約定的新容器時,遵循某些指南至關重要以確保其正確行為並與STL 庫整合。 迭代器介面:迭代器介面:定義一個具有適當的iterator_category標記的迭代器類,例如input_iterator_tag、output_iterator_tag、forwa...
    程式設計 發佈於2024-12-21
  • 為什麼 REST API 使用不同的 HTTP 方法(PUT、DELETE、POST、GET)?
    為什麼 REST API 使用不同的 HTTP 方法(PUT、DELETE、POST、GET)?
    REST API:HTTP 方法(PUT、DELETE、POST、GET)的重要性在RESTful API 領域,一個基本的問題出現了:為什麼要使用多種HTTP 請求類型,例如PUT、DELETE、POST 和GET?重要的是要了解 REST 的目的不僅僅是使用最簡單的方法存取資料。 REST 的角...
    程式設計 發佈於2024-12-21
  • 為什麼我的行動媒體查詢無法在行動裝置上運行?
    為什麼我的行動媒體查詢無法在行動裝置上運行?
    行動媒體查詢在行動裝置上不起作用:故障排除提示許多開發人員面臨行動裝置上CSS3 媒體查詢無回應的問題。如果您遇到此問題,讓我們根據您的查詢探索潛在的解決方案:在您的樣式表中,您正在使用行動裝置的媒體查詢,但在實際查看時它們似乎不起作用手機。相反,會顯示預設 CSS。 解決方案:驗證媒體查詢語法: ...
    程式設計 發佈於2024-12-21
  • 為什麼在 C++ 中使用 `` 時,`printf` 在 `std::printf` 和 `printf` 中都可以運作?
    為什麼在 C++ 中使用 `` 時,`printf` 在 `std::printf` 和 `printf` 中都可以運作?
    cstdio Stdio.h 命名空間cstdio Stdio.h 命名空間在 的C 參考文件中,它聲稱所有庫元素都駐留在std命名空間內。然而,實驗表明 std::printf 和 printf 函數呼叫都可以工作。這是否表示 C 頭檔案將符號名稱匯入 std 和全域命名空間? 答案包括 將符號...
    程式設計 發佈於2024-12-21
  • Go 中底線導入的目的是什麼?
    Go 中底線導入的目的是什麼?
    瞭解下劃線導入語句在 Go 程式設計世界中,導入語句前面的底線字元 ( _ ) 具有特定的意義。讓我們探討一下它的意義和用法。 下劃線導入的目的導入語句中的下劃線 (_ ) 表示導入該包只是為了其副作用。它不會從套件中匯入任何函數、方法或變數。 Go 套件中的副作用一些 Go 套件具有初始化函數(通...
    程式設計 發佈於2024-12-21
  • CMake 如何處理 GCC 專案中的調試和發佈建置?
    CMake 如何處理 GCC 專案中的調試和發佈建置?
    了解 CMake 中的調試與發布在 GCC 編譯專案中,CMake 為不同目標類型(調試/發布)配置建置設定提供了靈活性。以下是解決一些常見場景的方法:針對目標類型執行CMake要為偵錯和發布版本建立單獨的建置目錄,請按照下列步驟操作:mkdir Release cd Release cmake -...
    程式設計 發佈於2024-12-21
  • 我應該在 Python 腳本中使用 Shebang,如果是,使用哪一個?
    我應該在 Python 腳本中使用 Shebang,如果是,使用哪一個?
    我應該在 Python 腳本中包含 Shebang 嗎? 腳本中的 shebang 行允許直接從終端執行或透過檔案管理器,無需明確指定 python 命令。雖然它的包含是可選的,但通常被認為是一種方便的做法。 選擇正確的 Shebang 形式shebang 行的形式對於確保腳本可移植性至關重要。正確...
    程式設計 發佈於2024-12-21
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-12-21
  • 如何正確處理帶有空白邊界的 CSV 檔案?
    如何正確處理帶有空白邊界的 CSV 檔案?
    使用Scanner() 讀取CSV 問題使用Scanner() 讀取CSV 檔案時,通常會遇到文字包含空格的問題被移動到下一行。發生這種情況是因為 Scanner 遵循空格邊界。 Scanner() 用法中的 CSV 處理不正確提供的程式碼片段使用 Scanner() 讀取和處理 CSV 檔案。但是...
    程式設計 發佈於2024-12-21

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3