深入理解FastAPI的response_model:自动化数据验证与文档生成

使用 FastAPI 的 response_model 参数

在构建 RESTful API 时,确保数据的一致性和正确性是非常重要的。FastAPI 提供了强大的工具来帮助开发者实现这一目标。其中一个关键特性是 response_model 参数,它允许开发者定义期望的响应格式,并自动处理数据的序列化、验证和文档生成。

什么是 response_model

response_model 是 FastAPI 中的一个参数,它用于声明 API 响应的数据模型。这不仅可以确保响应数据的类型正确,还可以自动验证数据,并在 API 文档中为响应添加 JSON Schema。这意味着,使用 response_model,你可以减少手动编写和验证代码的工作量,同时提高 API 的可维护性和可读性。

response_model 的类型

response_model 可以接收多种类型的参数,包括:

  1. Pydantic 模型:这是最直接的用法,你可以定义一个 Pydantic 模型来描述响应的数据结构。
  2. Pydantic 模型列表:如果你的 API 需要返回一个对象列表,你可以使用 List[Model] 来声明。
response_model 的作用

使用 response_model 有以下几个好处:

  1. 数据转换:FastAPI 会自动将输出数据转换为声明的类型。
  2. 数据验证:在发送响应之前,FastAPI 会验证数据是否符合模型定义。
  3. JSON Schema:在 OpenAPI 的路径操作中,FastAPI 会为响应添加一个 JSON Schema,这有助于客户端理解响应结构。
  4. 文档生成:FastAPI 的自动文档系统会使用 response_model 来生成更准确的 API 文档。
简单的示例代码

简单的输出响应类

from fastapi import FastAPI
from pydantic import BaseModelapp = FastAPI()class Item(BaseModel):name: strdescription: str = Noneprice: floattax: float = None@app.get("/items/{item_id}", response_model=Item)
async def read_item(item_id: int):return {"name": "Item Name", "price": 10.5, "tax": 1.5}

在这个示例中,我们定义了一个 Item 模型,并在路由中使用 response_model=Item 来声明响应模型。这样,FastAPI 会自动处理响应数据的序列化和验证。

常见示例代码

将 ApiResponse 作为 response_model 并加入 token 验证的功能,一般用于登录和验证输出结果

from fastapi import FastAPI, Depends, HTTPException, Header
from pydantic import BaseModelapp = FastAPI()# 定义用户模型
class User(BaseModel):user_id: intname: strsex: int# 定义响应模型,包含嵌套的用户模型
class ApiResponse(BaseModel):status: strcode: intdata: User# 创建一个依赖项,用于获取请求头中的 token
def get_token(token: str = Header(None)):if token != "correct-token":raise HTTPException(status_code=401, detail="Invalid or missing token")return token# 创建一个路由,使用 ApiResponse 作为响应模型,并获取 token
@app.get("/user", response_model=ApiResponse)
async def get_user(token: str = Depends(get_token)):# 这里可以根据 token 进行一些逻辑处理,例如验证 token 并获取用户信息# 为了示例,我们直接返回一个固定的用户信息return ApiResponse(status="success",code=0,data=User(user_id=100, name="sdw", sex=0))# 运行应用
if __name__ == "__main__":import uvicornuvicorn.run(app, host="0.0.0.0", port=8000)

在这个示例中,我们做了以下修改:

  1. 定义模型:定义了 UserApiResponse 模型。
  2. 创建依赖项get_token 函数用于从请求头中获取 token 并进行验证。如果 token 不正确,抛出 HTTPException
  3. 使用 response_model:在 get_user 路由中,我们使用 response_model=ApiResponse 来指定响应模型。
  4. 处理请求:在 get_user 路由中,我们注入 get_token 依赖项,并返回一个 ApiResponse 实例。

要测试这个路由,你可以使用工具如 curl 或 Postman 发送一个带有正确 token 的 GET 请求:

curl -H "Authorization: Bearer correct-token" http://localhost:8000/user

这将返回预期的 JSON 响应。如果 token 不正确,将返回一个 401 错误。注意,我们将 token 放在 Authorization 请求头中,这是一种常见的做法。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/419436.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【HarmonyOS】- 内存优化

文章目录 知识回顾前言源码分析1. onMemoryLevel2. 使用LRUCache优化ArkTS内存原理介绍3. 使用生命周期管理优化ArkTS内存4. 使用purgeable优化C++内存拓展知识1. Purgeable Memory总结知识回顾 前言 当应用程序占用过多内存时,系统可能会频繁进行内存回收和重新分配,导致应…

Java中Date类型上的注解

在日常开发中,涉及到日期时间类型Date和常用的注解DateTimeFormat和JsonFormat java.util.Date; org.springframework.format.annotation.DateTimeFormat; com.fasterxml.jackson.annotation.JsonFormat; 一 Date类型字段不使用注解 Data AllArgsConstructor N…

开源还是封闭?人工智能的两难选择

这篇文章于 2024 年 7 月 29 日首次出现在 The New Stack 上。人工智能正处于软件行业的完美风暴中,现在马克扎克伯格 (Mark Zuckerberg) 正在呼吁开源 AI。 关于如何控制 AI 的三个强大观点正在发生碰撞: 1 . 所有 AI 都应该是开…

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥…

【软件设计师真题】下午题第一大题---数据流图设计

解答数据流图的题目关键在于细心。 考试时一定要仔细阅读题目说明和给出的流程图。另外,解题时要懂得将说明和流程图进行对照,将父图和子图进行对照,切忌按照常识来猜测。同时应按照一定顺序考虑问题,以防遗漏,比如可以…

Einsum(Einstein summation convention)

Einsum(Einstein summation convention) 笔记来源: Permute和Reshape嫌麻烦?einsum来帮忙! The Einstein summation convention is a notational shorthand used in tensor calculus, particularly in the fields of …

[数据集][目标检测]西红柿缺陷检测数据集VOC+YOLO格式17318张3类别

数据集格式:Pascal VOC格式YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):17318 标注数量(xml文件个数):17318 标注数量(txt文件个数):17318 标…

张飞硬件11~19-电容篇笔记

电容作用 作为源,对后级电路提供能量,对源进行充电。简单讲就是放电和充电。在电路设计中,源往往与负载相隔很远,增加电容就可以起到稳定作用。电容两端的电压不能激变,增加电容可以稳定电压。 电容可以类比为水坝&a…

(javaweb)mysql---DDL

一.数据模型,数据库操作 1.二维表:有行有列 2. 3.客户端连接数据库,发送sql语句给DBMS(数据库管理系统),DBMS创建--以文件夹显示 二.表结构操作--创建 database和schema含义一样。 这样就显示出了之前的内容…

系统编程--线程

这里写目录标题 线程概念什么是线程简介图解 内核原理图解 线程共享资源与非共享资源共享资源非共享资源 线程优缺点 线程控制原语pthread_self、pthread_create简介代码总结 循环创建多个子线程错误代码 线程间全局变量共享pthread_exit简介代码 pthread_join(回收…

传统CV算法——基于Sift算法实现特征点检测

图像尺度空间 在一定的范围内,无论物体是大还是小,人眼都可以分辨出来。然而,计算机要具备相同的能力却很难。因此,为了让机器能够对物体在不同尺度下有一个统一的认知,就需要考虑图像在不同尺度下所存在的特点。这就…

Infiniband网络架构的技术与性能分析

Infiniband格局寡头,性能占优 这篇文章探讨了网络交换机的性能优势,以及如何通过扩大模型参数量来提高语言模型的生成和预测能力。然而,计算约束对这种正向关系产生了重要影响,导致在相同的计算约束下,总存在最佳的模型…

Linux网络编程IO管理

网络 IO 涉及到两个系统对象,一个是用户空间调用 IO 的进程或者线程,一个是内核空间的内核系统,比如发生 IO 操作 read 时,它会经历两个阶段: 等待内核协议栈的数据准备就绪;将内核中的数据拷贝到用户态的…

随机森林Random Forest(RF)回归预测-MATLAB代码实现

一、随机森林RF(代码获取:底部公众号) 随机森林(Random Forest,RF)是一种机器学习方法,常用于回归预测和分类任务。它通过构建多个决策树,并通过组合它们的预测结果来进行回归预测。…

时序预测|基于粒子群优化支持向量机的时间序列预测Matlab程序PSO-SVM 单变量和多变量 含基础模型

时序预测|基于粒子群优化支持向量机的时间序列预测Matlab程序PSO-SVM 单变量和多变量 含基础模型 文章目录 一、基本原理1. 问题定义2. 数据准备3. SVM 模型构建4. 粒子群优化(PSO)5. 优化与模型训练6. 模型评估与预测7. 流程总结8. MATLAB 实现概述 二、…

浅谈人工智能之python调用通义千问API

浅谈人工智能之python调用通义千问API API-KEY建立 第一步:我们登录阿里云百炼 第二步:点击界面上查看我的API-KEY 第三步:在跳出来的界面中,点击创建API-KEY 第四步:在跳出来的界面中,在描述中输入“t…

算法——支持向量机(support vector machines,SVM)

简介:个人学习分享,如有错误,欢迎批评指正 支持向量机(Support Vector Machine, SVM)是一种监督学习算法,广泛用于分类任务,也可以用于回归和异常检测等问题。SVM的核心思想是通过在特征空间中找…

Unity【Colliders碰撞器】和【Rigibody刚体】的应用——小球反弹效果

目录 Collider 2D 定义: 类型: Rigidbody 2D 定义: 属性和行为: 运动控制: 碰撞检测: 结合使用 实用检测 延伸拓展 1、在Unity中优化Collider 2D和Rigidbody 2D的性能 2、Unity中Collider 2D…

2024/9/8周报

文章目录 摘要Abstract数据挖掘数据挖掘的目标数据挖掘的过程数据挖掘的技术应用领域工具与平台代码示例 总结 摘要 智慧水务项目中,需要对采集的总氮、氨氮、化学需氧量、硝态氮、总磷、硝态氮等数据进行数据处理与挖掘,因此本周对数据挖掘相关内容进行…

CommonCollections1

CommonCollections1 poc展示 这是一段POC,运行后会弹出一个计算器。 import org.apache.commons.collections.*; import org.apache.commons.collections.functors.ChainedTransformer; import org.apache.commons.collections.functors.ConstantTransformer; im…