【后端】FastAPI的Pydantic 模型

Pydantic是 FastAPI 用来"收"和"回"数据的格式说明书。

我们在写接口时,客户端会:

  • "传数据"给你(输入),比如注册/登录时提交用户名和密码。

  • "拿数据"回去(输出),比如你登录成功后返回 JWT 令牌。

👉 那这些数据怎么写?要哪些字段?什么类型?有没有格式限制?

Pydantic 模型就是用来定义这些数据格式的。


📥 举个例子:用户注册

你写了一个注册接口 /register,用户传来这个 JSON:

复制代码
{
  "username": "alice",
  "password": "123456"
}

你需要验证:

  • 有没有 username 字段?它是不是字符串?

  • password 有没有?是不是字符串?

👉 Pydantic 就是干这个活的

我们用 UserCreate 模型定义这个请求体结构:

复制代码
class UserCreate(BaseModel):
    username: str
    password: str

FastAPI 自动把用户提交的数据拿去套这个模型检查 。如果不符合(比如 password 是数字、username 没填),会直接返回错误,不会走到数据库或后续逻辑,保证你收到的就是干净合法的数据


📤 举个例子:登录响应

你登录成功了,要给客户端返回 JWT 令牌。你希望格式是这样的:

复制代码
{
  "access_token": "xxxxx",
  "token_type": "bearer"
}

我们用这个模型描述这个结构:

复制代码
class Token(BaseModel):
    access_token: str
    token_type: str

FastAPI 自动会把你写在返回值里的字典转成这个格式,客户端拿回的 JSON 就规范了。


🧩 Pydantic 模型 = 两件事:

模型名 干的事(请求) 干的事(响应)
UserCreate 验证用户提交的数据是否合法 不用于响应
Token 不用于请求 定义你返回给用户的令牌格式

🔄 总结一句话

你可以把 Pydantic 理解成"接口数据说明书"。

  • 当别人调用你的接口时,FastAPI 用它来帮你检查数据合法性 ✅

  • 当你返回数据给别人时,FastAPI 用它来帮你自动生成标准 JSON 📦

相关推荐
舒一笑4 小时前
PandaCoder:致敬MyBatis Log Plugin,但我们做得更极致!
后端·程序员·intellij idea
飞翔的佩奇5 小时前
【完整源码+数据集+部署教程】【天线&水】舰船战舰检测与分类图像分割系统源码&数据集全套:改进yolo11-repvit
前端·python·yolo·计算机视觉·数据集·yolo11·舰船战舰检测与分类图像分割系统
钱彬 (Qian Bin)6 小时前
项目实践4—全球证件智能识别系统(Qt客户端开发+FastAPI后端人工智能服务开发)
人工智能·qt·fastapi
简单点了6 小时前
go前后端项目的启动 、打包和部署
开发语言·后端·golang
钱彬 (Qian Bin)6 小时前
项目实践3—全球证件智能识别系统(Qt客户端开发+FastAPI后端人工智能服务开发)
人工智能·qt·fastapi
Microsoft Word6 小时前
向量数据库与RAG
数据库·人工智能·向量数据库·rag
木头左6 小时前
最大回撤约束下ETF多因子动态止盈参数校准方案
python
汤姆yu6 小时前
2026版基于python的协同过滤音乐推荐系统
开发语言·python
汤姆yu6 小时前
基于python的电子商务管理系统
开发语言·python
may_一一6 小时前
pycharm\python 安装下载
ide·python·pycharm