Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> Co-authored-by: Motov Yurii <109919500+YuriiMotov@users.noreply.github.com> Co-authored-by: Yurii Motov <yurii.motov.monte@gmail.com>
3.7 KiB
路径操作配置
路径操作装饰器支持多种配置参数。
/// warning | 警告
注意:以下参数应直接传递给路径操作装饰器,不能传递给路径操作函数。
///
响应状态码
可以在路径操作的响应中定义(HTTP)status_code。
可以直接传递 int 代码,比如 404。
如果记不住数字码的含义,也可以用 status 的快捷常量:
{* ../../docs_src/path_operation_configuration/tutorial001_py310.py hl[1,15] *}
该状态码会用于响应中,并会被添加到 OpenAPI 概图。
/// note | 技术细节
也可以使用 from starlette import status 导入状态码。
FastAPI 提供的 fastapi.status 与 starlette.status 相同,方便你作为开发者使用。实际上它直接来自 Starlette。
///
标签
可以通过传入由 str 组成的 list(通常只有一个 str)的参数 tags,为路径操作添加标签:
{* ../../docs_src/path_operation_configuration/tutorial002_py310.py hl[15,20,25] *}
OpenAPI 概图会自动添加标签,供 API 文档接口使用:
使用 Enum 的标签
如果你的应用很大,可能会积累出很多标签,你会希望确保相关的路径操作始终使用相同的标签。
这种情况下,把标签存放在 Enum 中会更合适。
FastAPI 对此的支持与使用普通字符串相同:
{* ../../docs_src/path_operation_configuration/tutorial002b_py39.py hl[1,8:10,13,18] *}
摘要和描述
可以添加 summary 和 description:
{* ../../docs_src/path_operation_configuration/tutorial003_py310.py hl[17:18] *}
从 docstring 获取描述
描述内容比较长且占用多行时,可以在函数的 docstring 中声明路径操作的描述,FastAPI 会从中读取。
文档字符串支持 Markdown,能正确解析和显示 Markdown 的内容,但要注意文档字符串的缩进。
{* ../../docs_src/path_operation_configuration/tutorial004_py310.py hl[17:25] *}
下图为 Markdown 文本在 API 文档中的显示效果:
响应描述
response_description 参数用于定义响应的描述说明:
{* ../../docs_src/path_operation_configuration/tutorial005_py310.py hl[18] *}
/// info | 说明
注意,response_description 只用于描述响应,description 一般则用于描述路径操作。
///
/// check | 检查
OpenAPI 规定每个路径操作都要有响应描述。
如果没有定义响应描述,FastAPI 则自动生成内容为 "Successful response" 的响应描述。
///
弃用路径操作
deprecated 参数可以把路径操作标记为弃用,无需直接删除:
{* ../../docs_src/path_operation_configuration/tutorial006_py39.py hl[16] *}
API 文档会把该路径操作标记为弃用:
下图显示了正常路径操作与弃用路径操作 的区别:
小结
通过传递参数给路径操作装饰器,即可轻松地配置路径操作、添加元数据。