当前位置: 首页 > news >正文

FastAPI自定义异常处理:优雅转换Pydantic校验错误

FastAPI自定义异常处理:优雅转换Pydantic校验错误

背景需求

当使用FastAPI开发API服务时,Pydantic的自动校验异常默认会返回如下格式的422响应:

{"detail": [{"type": "missing","loc": ["body", "user", "name"],"msg": "Field required","input": null}]
}

但在实际开发中我们通常需要:

  1. 统一异常响应格式
  2. 增加自定义错误码
  3. 对敏感信息进行过滤
  4. 支持多语言错误提示

实现方案

步骤1:创建自定义异常类

from fastapi import HTTPExceptionclass APIException(HTTPException):def __init__(self,code: int = 40000,message: str = "请求参数错误",status_code: int = 400,**kwargs):super().__init__(status_code=status_code,detail={"code": code,"message": message,"data": kwargs.get("data", None)})

步骤2:捕获Pydantic校验异常

2.1 异常捕获机制原理

2.1.1 FastAPI的异常处理链
# FastAPI的异常处理流程示意图
客户端请求 -> 路由函数 -> 中间件处理 -> 参数校验 -> 业务逻辑 -> 返回响应↑异常捕获点               ↑校验异常触发点异常处理器介入 ←─ 异常抛出
  • 捕获时机:当请求参数不符合Pydantic模型定义时,框架会自动抛出RequestValidationError(HTTP 422错误)
  • 处理器注册:通过@app.exception_handler装饰器绑定特定异常类型到处理函数
2.1.2 关键异常类型区分
异常类型触发场景继承关系
ValidationError手动调用模型验证时抛出Pydantic原生异常
RequestValidationErrorFastAPI自动参数校验失败继承自ValidationError

2.2 核心处理逻辑剖析

2.2.1 错误数据结构解构
# 原始错误条目结构示例
{"type": "value_error",       # 错误大类"loc": ("body", "age"),      # 错误位置元组"msg": "输入值不是合法整数",   # 原始错误描述"input": "eighteen"          # 客户端原始输入
}

字段深度说明

  • loc定位器:

    • 遵循(位置类型, 字段路径...)结构
    • 位置类型可能为:body, query, path, header, cookie
    • 嵌套字段示例:("body", "user", "address", "city")
  • 常见错误类型:

    # Pydantic预定义错误类型参考
    "missing"            # 必填字段缺失
    "value_error"        # 值校验失败
    "type_error"         # 类型不匹配
    "assertion_error"    # 自定义校验断言失败
    
2.2.2 错误信息处理流程
def 

相关文章:

  • java+selenium专题->启动浏览器下篇
  • 百胜ECOVADIS认证咨询公司,ecovadis评分提升攻略
  • 凸优化理论-进阶方法
  • Vue.js教学第六章:Vue 开发的高效路径,组件化基础
  • AI自动化工作流:开启当下智能生产力的价值
  • 2025 BYUCTF re 部分wp
  • 嵌入式学习笔记 D22:栈与队列
  • 板凳-------Mysql cookbook学习 (四)
  • GPU硬件计数器深度用法:通过NVIDIA Nsight Compute定位隐藏的性能瓶颈——以DRAM访问模式对带宽利用率影响分析为例
  • 第2篇 水滴穿透:IGBT模块的绝对防御体系
  • Python数据可视化初探——“十八般兵器”介绍
  • 嵌入式系统中,检测链路层(物理层)状态变化时,选择中断驱动还是定时轮询
  • 【每天一个知识点】embedding与representation
  • 为什么上传大量大文件推荐是使用 app 应用为不是 web 浏览器下载上传呢?
  • PLC组网的方法、要点及实施全解析
  • 网络传输(ping命令,wget命令,curl命令),端口
  • 代码随想录算法训练营第四十四天
  • 开发体育比分网站,有哪些坑需要注意的
  • 创建型:抽象工厂模式
  • C#:多线程
  • 复旦兼职教授高纪凡首秀,勉励学子“看三十年才能看见使命”
  • 世卫大会连续九年拒绝涉台提案
  • 上海公办小学验证今起开始,下周一和周二分区进行民办摇号
  • 信俗与共:清代新疆回疆儒释道庙宇的中华政教
  • 坚决打好产业生态培育攻坚战!陈吉宁调研奉贤区
  • 浙江省委金融办原副主任潘广恩被“双开”