前言
- 目前的接口基本都是通过发送请求体(Request Body)的方式来传递请求数据
- 在 FastAPI,提倡使用 Pydantic 模型来定义请求体
- 这篇文章会详细讲不使用 Pydantic 和 使用 Pydantic 时的场景
注意
- 请求体并不是只有 POST 请求有,只不过更常见
- 在 PUT、DELETE、PATCH 请求中都可以使用请求体
- 其实,在 GET 请求中也可以用请求体,不过仅适用于非常极端的情况下,而且 Swagger API 并不会显示 GET 请求的请求体
不使用 Pydantic的栗子
from fastapi import FastAPI
import uvicorn
app = FastAPI()
@app.post("/items")
async def read_item(item: dict):
return {
"item": item}
if __name__ == "__main__":
uvicorn.run(app="6_request:app", host="127.0.0.1", port=8080, reload=True, debug=True)
指定查询参数的类型为 dict