>  기사  >  백엔드 개발  >  FastAPI에서 동일한 경로 매개변수를 사용하여 여러 API 엔드포인트를 정의하는 방법은 무엇입니까?

FastAPI에서 동일한 경로 매개변수를 사용하여 여러 API 엔드포인트를 정의하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-10-30 17:08:02410검색

How to Define Multiple API Endpoints with the Same Path Parameter in FastAPI?

FastAPI에서 동일한 경로 매개변수로 여러 API 엔드포인트 정의

FastAPI에서 경로 매개변수는 동일하지만 서로 다른 여러 API 엔드포인트 정의 경로는 간단하지 않습니다. 엔드포인트 평가 순서가 중요하므로 요청의 특정 경로에 관계없이 먼저 정의된 엔드포인트가 항상 트리거됩니다.

문제

다음 라우터 파일을 고려하세요. 세 개의 엔드포인트가 정의되어 있으며 각각 경로는 다르지만 "project_id" 경로 매개변수를 공유합니다.

</p>
<h1>GET API 엔드포인트 1</h1>
<p>@router.get("/project/{project_id}/{employee_id}")<br>async def method_one(project_id: str, organization_id: str, session: AsyncSession = 종속(get_db)):</p> <pre class="brush:php;toolbar:false"># ...

API 엔드포인트 2 가져오기

@router.get("/project/details/{project_id}")
async def method_two(project_id: str, session: AsyncSession = 종속(get_db) )):

# ...

API 엔드포인트 3 가져오기

@router.get("/project/metadata/{project_id}")
async def method_two(project_id: str, session : AsyncSession = 종속(get_db)):

# ...

이 코드는 API 끝점 2와 3이 끝점 1에 정의된 컨트롤러 메서드(method_one)를 호출하는 예기치 않은 동작을 나타냅니다. ()).

이유

FastAPI에서는 엔드포인트 평가가 순차적으로 발생합니다. 따라서 엔드포인트 1("/project/{project_id}/{employee_id}")이 먼저 평가됩니다. 엔드포인트 2 또는 엔드포인트 3에 대한 후속 요청이 이루어지면 FastAPI는 경로의 "/project/{project_id}" 부분을 엔드포인트 1의 project_id 매개변수로 해석합니다. 이로 인해 엔드포인트 1에 대한 컨트롤러 메서드가 호출됩니다.

해결책

이 문제를 해결하려면 동일한 경로 매개변수를 가진 엔드포인트가 추가 경로를 포함하는 엔드포인트보다 먼저 정의되도록 엔드포인트 정의 순서를 반대로 해야 합니다. 매개변수:

</p>
<h1>GET API 엔드포인트 2</h1>
<p>@router.get("/project/details/{project_id} ")</p>
<pre class="brush:php;toolbar:false"># ...

API 엔드포인트 3 가져오기

@router.get("/project/metadata/{project_id}")

# ...

API 엔드포인트 1 가져오기

@router.get("/project/{project_id}/{employee_id}")

# ...

이러한 수정을 통해 FastAPI는 엔드포인트 2와 3을 먼저 평가하여 해당 엔드포인트에 대한 요청이 있을 때 적절한 컨트롤러 메서드가 실행되는지 확인합니다.

위 내용은 FastAPI에서 동일한 경로 매개변수를 사용하여 여러 API 엔드포인트를 정의하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.