在FastAPI 中,定義具有相同路徑參數但不同的多個API 端點路徑並不簡單。由於端點評估的順序很重要,無論請求的特定路徑如何,首先定義的端點都將始終被觸發。
考慮以下路由器檔案其中定義了三個端點,每個端點具有不同的路徑,但共用「project_id」路徑參數:
</p><h1>GET API Endpoint 1</h1><p>@router.get("/project/{project_id}/{employee_id}")<br> async def method_one(project_id: str,organization_id: str, session: AsyncSession = Depends(get_db)):</p> <pre class="brush:php;toolbar:false"># ...
GET API 端點2
GET API 端點
# ...GET API 端點
.get("/project/metadata/{project_id}")
async def method_two(project_id: str, session) : AsyncSession = Depends(get_db)):🎜><p>此程式碼表現出意外行為,其中API 端點2 和3 呼叫端點1 中定義的控制器方法(method_one ()).</p><p></p><h3>原因</h3> <p>在FastAPI 中,端點評估是依序發生的。因此,首先評估端點 1(“/project/{project_id}/{employee_id}”)。當向端點 2 或端點 3 發出後續請求時,FastAPI 會將路徑的「/project/{project_id}」部分解釋為端點 1 的 project_id 參數。這會導致呼叫端點 1 的控制器方法。 </p><p></p><h3>解</h3><br>要解決此問題,應顛倒端點定義的順序,以便在包含附加路徑的端點之前定義具有相同路徑參數的端點參數: <h1><pre class="lang-py Prettyprint-override"></h1><p>GET API 端點2</p><pre class="brush:php;toolbar:false"># ...@router.get("/project/details/{project_id} ")
取得API 端點3
# ...@router.get("/project/metadata/{project_id}")
取得API 端點1
# ...@router.get("/project/{project_id}/{employee_id}")透過進行此修改,FastAPI將首先評估端點2和3,確保在向這些端點發出請求時執行適當的控制器方法。
以上是如何在 FastAPI 中使用相同路徑參數定義多個 API 端點?的詳細內容。更多資訊請關注PHP中文網其他相關文章!