Files
fastapi/docs/zh/docs/advanced/response-change-status-code.md
Sebastián Ramírez 376e108580 🌐 Update translations for zh (update-outdated) (#14843)
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>
2026-02-08 11:39:41 +01:00

1.5 KiB
Raw Blame History

响应 - 更改状态码

你可能之前已经了解到,你可以设置默认的响应状态码{.internal-link target=_blank}。

但在某些情况下,你需要返回一个不同于默认值的状态码。

使用场景

例如假设你想默认返回一个HTTP状态码为“OK”200

但如果数据不存在你想创建它并返回一个HTTP状态码为“CREATED”201

但你仍然希望能够使用response_model过滤和转换你返回的数据。

对于这些情况,你可以使用一个Response参数。

使用 Response 参数

你可以在你的路径操作函数中声明一个Response类型的参数就像你可以为cookies和头部做的那样

然后你可以在这个临时响应对象中设置status_code

{* ../../docs_src/response_change_status_code/tutorial001_py39.py hl[1,9,12] *}

然后你可以像平常一样返回任何你需要的对象(例如一个dict或者一个数据库模型)。如果你声明了一个response_model,它仍然会被用来过滤和转换你返回的对象。

FastAPI将使用这个临时响应来提取状态码也包括cookies和头部并将它们放入包含你返回的值的最终响应中该响应由任何response_model过滤。

你也可以在依赖项中声明Response参数,并在其中设置状态码。但请注意,最后设置的状态码将会生效。