FastAPI 中具有路徑參數的多個API 端點
在FastAPI 定義具有路徑結構變化的多個API 端點,同時共用路徑參數可能會導致意外的行為。在提供的程式碼範例中,您遇到一個問題,即為所有 API 端點執行「method_one」控制器,無論其指定的路徑為何。
了解路徑匹配
在 FastAPI 中,端點定義的順序至關重要。路徑匹配是從應用程式中聲明的第一個端點進行評估的。因此,「/project/{project_id}/{employee_id}」的端點首先被評估,並且所有其他端點的路徑參數都被解釋為 project_id 參數的一部分。
解決方案
要解決此問題,您需要確保具有更具體路徑的端點在具有更通用路徑的端點之前定義。這可確保 FastAPI 首先評估最具體的端點,且路徑參數會如預期相符。
修正後的程式碼範例將如下所示:
<code class="python"># GET API Endpoint 2 @router.get("/project/details/{project_id}") async def method_two( project_id: str, session: AsyncSession = Depends(get_db) ): # ... # GET API Endpoint 3 @router.get("/project/metadata/{project_id}") async def method_three( project_id: str, session: AsyncSession = Depends(get_db) ): # ... # GET API Endpoint 1 @router.get("/project/{project_id}/{employee_id}") async def method_one( project_id: str, employee_id: str, session: AsyncSession = Depends(get_db) ): # ...</code>
透過此調整,最具體的端點端點(/project/details/{project_id} 和/project/metadata/{ project_id})將在更通用的端點(/project/{project_id}/{employee_id})之前進行評估,確保執行正確的控制器方法每個API 端點。
以上是為什麼我的 FastAPI 端點「method_one」總是被執行,無論路徑如何?的詳細內容。更多資訊請關注PHP中文網其他相關文章!