如何在 FastAPI 中使用相同路径参数定义多个 API 端点?

Patricia Arquette
发布: 2024-10-30 17:08:02
原创
408 人浏览过

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

在 FastAPI 中定义具有相同路径参数的多个 API 端点

在 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> <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_two(project_id: str, session) : AsyncSession = Depends(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><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"># ...
登录后复制
登录后复制

获取 API 端点 3

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

# ...
登录后复制
登录后复制

获取 API 端点 1

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

# ...
登录后复制
登录后复制

通过进行此修改,FastAPI将首先评估端点 2 和 3,确保在向这些端点发出请求时执行适当的控制器方法。

以上是如何在 FastAPI 中使用相同路径参数定义多个 API 端点?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
上一篇:为什么 `list.__iadd__` 会修改原始列表和分配的列表,而 `list.__add__` 只修改分配的列表? 下一篇:如何在Python中有效地解析固定宽度的文件行?
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
关于CSS思维导图的课件在哪? 课件
来自于 2024-04-16 10:10:18
0
0
1541
相关专题
更多>
热门推荐
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!