FastAPI学习-19.response 参数-修改状态码
前言
假设你想默认返回一个HTTP状态码为“OK”200
。
但如果数据不存在,你想创建它,并返回一个HTTP状态码为“CREATED”201
。
但你仍然希望能够使用response_model
过滤和转换你返回的数据。
对于这些情况,你可以使用一个response`参数。
使用 response
参数
status_code 设置默认状态码
from fastapi import FastAPI, Response, status
app = FastAPI()
tasks = {"foo": "Listen to the Bar Fighters"}
@app.put("/get-or-create-task/{task_id}", status_code=200)
def get_or_create_task(task_id: str, response: Response):
if task_id not in tasks:
tasks[task_id] = "This didn't exist before"
response.status_code = status.HTTP_201_CREATED
return tasks[task_id]
然后你可以像平常一样返回任何你需要的对象(例如一个dict
或者一个数据库模型)。如果你声明了一个response_model
,它仍然会被用来过滤和转换你返回的对象。
FastAPI将使用这个临时响应来提取状态码(也包括cookies和头部),并将它们放入包含你返回的值的最终响应中,该响应由任何response_model
过滤。
返回Response 对象
也可以直接返回 Respouse 对象
from fastapi import Response, status
tasks = {"foo": "Listen to the Bar Fighters"}
@app.put("/task/{task_id}", status_code=200)
def get_or_create_task(task_id: str):
if task_id == '2':
return Response('{"msg": "ok"}', status_code=202, media_type='application/json')
return tasks[task_id]
测试
PUT http://127.0.0.1:8000/task/2 HTTP/1.1
User-Agent: Fiddler
Host: 127.0.0.1:8000
Content-Type: application/json
Content-Length: 0
HTTP/1.1 202 Accepted
date: Sun, 17 Sep 2023 02:11:46 GMT
server: uvicorn
content-length: 13
content-type: application/json
{"msg": "ok"}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2022-09-17 node.js 使用教程-2.Gulp 打包构建入门与使用
2021-09-17 python测试开发django-135.CSS如何让左侧浮动(float)元素占满屏幕高度
2021-09-17 python测试开发django-134.CSS页面布局:左侧固定,右侧自适应布局
2020-09-17 pytest文档59-运行未提交git的用例(pytest-picked)
2018-09-17 python笔记28-lxml.etree爬取html内容
2018-09-17 python笔记27-lxml.etree解析html