FastAPI で同じパス パラメーターを使用して複数の API エンドポイントを定義するにはどうすればよいですか?
FastAPI で同じパス パラメータを持つ複数の API エンドポイントを定義する
FastAPI で、同じパス パラメータで異なる複数の API エンドポイントを定義する道は単純ではありません。エンドポイント評価の順序が重要であるため、リクエストの特定のパスに関係なく、最初に定義されたエンドポイントが常にトリガーされます。
問題
次のルーター ファイルについて考えてみましょう。ここで 3 つのエンドポイントが定義されており、それぞれ異なるパスを持ちますが、「project_id」パス パラメーターを共有しています:
</p> <h1 id="GET-API-Endpoint">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> <div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false"># ...
GET API エンドポイント 2
@router.get("/project/details/{project_id}")
async def method_two(project_id: str, session: AsyncSession = depends(get_db) )):
# ...
GET API エンドポイント 3
@router.get("/project/metadata/{project_id}")
async def method_three(project_id: str, session : AsyncSession = depends(get_db)):
# ...
このコードは、API エンドポイント 2 および 3 がエンドポイント 1 で定義されたコントローラー メソッド (method_one) を呼び出すときに予期しない動作を示します。 ()).
Reason
FastAPI では、エンドポイントの評価は順番に行われます。したがって、エンドポイント 1 (「/project/{project_id}/{employee_id}」) が最初に評価されます。後続のリクエストがエンドポイント 2 またはエンドポイント 3 に対して行われると、FastAPI はパスの「/project/{project_id}」部分をエンドポイント 1 の project_id パラメーターとして解釈します。これにより、エンドポイント 1 のコントローラー メソッドが呼び出されます。
解決策
この問題を解決するには、エンドポイント定義の順序を逆にして、同じパス パラメーターを持つエンドポイントが追加のパスを含むエンドポイントの前に定義されるようにする必要があります。パラメータ:
</p> <h1 id="GET-API-エンドポイント">GET API エンドポイント 2</h1> <p>@router.get("/project/details/{project_id} ")</p> <div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false"># ...
GET API エンドポイント 3
@router.get("/project/metadata/{project_id}")
# ...
GET API エンドポイント 1
@router.get("/project/{project_id}/{employee_id}")
# ...
この変更を行うことで、FastAPIは最初にエンドポイント 2 と 3 を評価し、それらのエンドポイントにリクエストが行われたときに適切なコントローラー メソッドが実行されるようにします。
以上がFastAPI で同じパス パラメーターを使用して複数の API エンドポイントを定義するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









