FastAPI(8)- 请求体 Request Body

本文详述了在FastAPI中如何处理请求体,包括不使用Pydantic和使用Pydantic模型的情况。重点介绍了Pydantic模型的优势,如数据转换、验证、智能提示,并给出了错误处理示例。同时,展示了FastAPI如何识别并处理请求体、路径参数和查询参数。
摘要由CSDN通过智能技术生成

前言

  • 目前的接口基本都是通过发送请求体(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

正确传参的请求结果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小菠萝测试笔记

来支持下测试小锅锅

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值