FastAPI 错误处理与自定义错误消息完全指南:构建健壮的 API 应用 ️

news/2025/3/12 0:56:41/文章来源:https://www.cnblogs.com/Amd794/p/18766571

title: FastAPI 错误处理与自定义错误消息完全指南:构建健壮的 API 应用 🛠️
date: 2025/3/12
updated: 2025/3/12
author: cmdragon

excerpt:
我们将涵盖常见的错误类型、如何捕获和处理这些错误、以及如何返回自定义的错误消息。通过实例和最佳实践,您将能够有效地应对常见错误,提高 API 的鲁棒性和可维护性。此外,文章中包含课后测验和常见错误解决方案,帮助您巩固所学知识。

categories:

  • 后端开发
  • FastAPI

tags:

  • FastAPI
  • 错误处理
  • 自定义错误消息
  • API设计
  • Web开发
  • 数据校验
  • 开发最佳实践

image
image

image

扫描二维码关注或者微信搜一搜:编程智域 前端至全栈交流与成长

探索数千个预构建的 AI 应用,开启你的下一个伟大创意

第一章:FastAPI 中的错误处理基础

1.1 什么是错误处理?

错误处理是指在应用程序运行过程中,捕获和处理可能发生的错误,确保程序能够优雅地处理异常情况并给出适当的反馈。

1.2 FastAPI 的默认错误响应

FastAPI 提供了内置的错误处理机制,能够自动返回 HTTP 状态码和错误信息。例如,当请求的资源不存在时,会返回 404 错误。

from fastapi import FastAPI, HTTPExceptionapp = FastAPI()@app.get("/items/{item_id}")
async def read_item(item_id: int):if item_id != 1:raise HTTPException(status_code=404, detail="Item not found")return {"item_id": item_id}

1.3 常见的 HTTP 错误状态码

  • 400 Bad Request:请求参数无效或缺失。
  • 404 Not Found:请求的资源未找到。
  • 422 Unprocessable Entity:请求格式正确,但内容有误。
  • 500 Internal Server Error:服务器内部错误。

第二章:自定义错误消息

2.1 自定义错误响应

您可以通过自定义错误响应来改善用户体验,提供更清晰的错误信息。

from fastapi import Request, FastAPI, HTTPException
from fastapi.responses import JSONResponseapp = FastAPI()@app.exception_handler(HTTPException)
async def http_exception_handler(request: Request, exc: HTTPException):return JSONResponse(status_code=exc.status_code,content={"detail": exc.detail, "error": "Custom error message"},)

2.2 示例:使用自定义错误消息

在前面的例子中,如果请求的资源未找到,将返回自定义的错误消息。

@app.get("/items/{item_id}")
async def read_item(item_id: int):if item_id != 1:raise HTTPException(status_code=404, detail="Item not found")return {"item_id": item_id}

示例请求

curl "http://localhost:8000/items/2"

返回

{"detail": "Item not found","error": "Custom error message"
}

2.3 处理其他异常

除了 HTTPException,您还可以处理其他类型的异常,例如数据库连接错误。

@app.exception_handler(Exception)
async def generic_exception_handler(request: Request, exc: Exception):return JSONResponse(status_code=500,content={"detail": "An unexpected error occurred", "error": str(exc)},)

第三章:最佳实践

3.1 记录错误

在生产环境中,记录错误信息是非常重要的,可以帮助您排查问题。

import logginglogging.basicConfig(level=logging.INFO)@app.exception_handler(Exception)
async def generic_exception_handler(request: Request, exc: Exception):logging.error(f"Unexpected error: {exc}")return JSONResponse(status_code=500,content={"detail": "An unexpected error occurred"},)

3.2 课后测验

  1. 如何在 FastAPI 中捕获和处理所有未处理的异常?
  2. 当请求参数不符合预期时,FastAPI 会返回什么错误?如何自定义这个错误的响应?
  3. 提供一个如何避免 SQL 注入攻击的示例。

3.3 常见错误与解决方案

错误:422 Validation Error
原因:请求数据格式不正确或缺失必填字段。
解决方案:检查请求体或查询参数的格式和必填性。

错误:404 Not Found
原因:请求的资源不存在。
解决方案:确认请求的 URL 是否正确,资源是否存在。

错误:500 Internal Server Error
原因:服务器内部错误。
解决方案:检查服务器日志,确认是否存在未处理的异常。


通过本教程,您应该能够掌握 FastAPI 中的错误处理机制和自定义错误消息的技巧,为构建更健壮的 API 应用打下基础。

余下文章内容请点击跳转至 个人博客页面 或者 扫码关注或者微信搜一搜:编程智域 前端至全栈交流与成长,阅读完整的文章:FastAPI 错误处理与自定义错误消息完全指南:构建健壮的 API 应用 🛠️ | cmdragon's Blog

往期文章归档:

  • FastAPI 自定义参数验证器完全指南:从基础到高级实战 | cmdragon's Blog
  • FastAPI 参数别名与自动文档生成完全指南:从基础到高级实战 🚀 | cmdragon's Blog
  • FastAPI Cookie 和 Header 参数完全指南:从基础到高级实战 🚀 | cmdragon's Blog
  • FastAPI 表单参数与文件上传完全指南:从基础到高级实战 🚀 | cmdragon's Blog
  • FastAPI 请求体参数与 Pydantic 模型完全指南:从基础到嵌套模型实战 🚀 | cmdragon's Blog
  • FastAPI 查询参数完全指南:从基础到高级用法 🚀 | cmdragon's Blog
  • FastAPI 路径参数完全指南:从基础到高级校验实战 🚀 | cmdragon's Blog
  • FastAPI路由专家课:微服务架构下的路由艺术与工程实践 🌐 | cmdragon's Blog
  • FastAPI路由与请求处理进阶指南:解锁企业级API开发黑科技 🔥 | cmdragon's Blog
  • FastAPI路由与请求处理全解:手把手打造用户管理系统 🔌 | cmdragon's Blog
  • FastAPI极速入门:15分钟搭建你的首个智能API(附自动文档生成)🚀 | cmdragon's Blog
  • HTTP协议与RESTful API实战手册(终章):构建企业级API的九大秘籍 🔐 | cmdragon's Blog
  • HTTP协议与RESTful API实战手册(二):用披萨店故事说透API设计奥秘 🍕 | cmdragon's Blog
  • 从零构建你的第一个RESTful API:HTTP协议与API设计超图解指南 🌐 | cmdragon's Blog
  • Python异步编程进阶指南:破解高并发系统的七重封印 | cmdragon's Blog
  • Python异步编程终极指南:用协程与事件循环重构你的高并发系统 | cmdragon's Blog
  • Python类型提示完全指南:用类型安全重构你的代码,提升10倍开发效率 | cmdragon's Blog
  • 三大平台云数据库生态服务对决 | cmdragon's Blog
  • 分布式数据库解析 | cmdragon's Blog
  • 深入解析NoSQL数据库:从文档存储到图数据库的全场景实践 | cmdragon's Blog
  • 数据库审计与智能监控:从日志分析到异常检测 | cmdragon's Blog
  • 数据库加密全解析:从传输到存储的安全实践 | cmdragon's Blog
  • 数据库安全实战:访问控制与行级权限管理 | cmdragon's Blog
  • 数据库扩展之道:分区、分片与大表优化实战 | cmdragon's Blog
  • 查询优化:提升数据库性能的实用技巧 | cmdragon's Blog
  • 性能优化与调优:全面解析数据库索引 | cmdragon's Blog
  • 存储过程与触发器:提高数据库性能与安全性的利器 | cmdragon's Blog
  • 数据操作与事务:确保数据一致性的关键 | cmdragon's Blog
  • 深入掌握 SQL 深度应用:复杂查询的艺术与技巧 | cmdragon's Blog
  • 彻底理解数据库设计原则:生命周期、约束与反范式的应用 | cmdragon's Blog
  • 深入剖析实体-关系模型(ER 图):理论与实践全解析 | cmdragon's Blog
  • 数据库范式详解:从第一范式到第五范式 | cmdragon's Blog
  • PostgreSQL:数据库迁移与版本控制 | cmdragon's Blog
  • Node.js 与 PostgreSQL 集成:深入 pg 模块的应用与实践 | cmdragon's Blog
  • Python 与 PostgreSQL 集成:深入 psycopg2 的应用与实践 | cmdragon's Blog

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

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

相关文章

基于Flask的Web应用开发

基于Flask的Web应用开发项目来源:[【基于Flask的Web应用开发-01.应用介绍及Flask安装_s】](【基于Flask的Web应用开发-01.应用介绍及Flask安装_s】 https://www.bilibili.com/video/BV1r94y1j7uW/?share_source=copy_web&vd_source=d0886da49a29063777f2956d5780b087) 原…

vitest遇到的一个小问题:scrollTo is not a function

给tdesign-mobile-vue提了一个pr,验收通过了但是单测流水线报错了看报错是组件里的错误,scrollTo is not a function 组件代码的大概逻辑如下 const navScroll = ref<HTMLElement>(); // ... if (navScroll.value) {const tab = navScroll.value.querySelector < HT…

《Python极客编程 : 用代码探索世界》 | PDF免费下载

16个有趣的编程项目,项目式的学习方法,有趣案例提升Python编程技能,培养解决现实问题的思维,附赠源代码,适合零基础计算机小白入门学习。点击下载书籍信息 作者: [美]李沃恩(Lee Vaughan) 出版社: 人民邮电出版社 副标题: 用代码探索世界 译者: 王海鹏 出版年: 2022-8-1…

密度大于0.9408

题目: from Crypto.Util.number import * import random from Crypto.Cipher import AES import hashlib from Crypto.Util.Padding import pad from secrets import flaglist = [] bag = [] p=random.getrandbits(64) assert len(bin(p)[2:])==64 for i in range(4):t = pa=[g…

背包密码密度的作用(LLL算法的实现)

背包问题通解: 当密度d满足以下条件时,LLL算法能有效地解决这类背包问题![](https://cdn.nlark.com/yuque/0/2025/png/49294098/1739349426771-401f2fa7-aefe-422b-b642-5d8f664c415d.png)其中:len(M)是向量M的长度,即向量中元素的数量 max(Mi)是向量M中的最大元素计算: import…

Elliptic(椭圆)曲线

题目: from Crypto.Util.number import getPrime from libnum import s2n from secret import flagp = getPrime(256) a = getPrime(256) b = getPrime(256) E = EllipticCurve(GF(p),[a,b]) m = E.random_point() G = E.random_point() k = getPrime(256) K = k * G r = getPr…

Twisted Hessian曲线(求a)

题目: from Crypto.Util.number import * from Crypto.Cipher import AES from Crypto.Util.Padding import pad from random import randint import hashlib from secrets import flagdef add_THCurve(P, Q):if P == (0, 0):return Qif Q == (0, 0):return Px1, y1 = Px2, y2 …

基于双PI控制器结构的六步逆变器供电无刷直流电机调速simulink仿真

1.课题概述基于双PI控制器结构的六步逆变器供电无刷直流电机调速simulink仿真。双PI控制器是一种结合了两个独立的PI控制器的控制策略,用于提高系统的稳定性和动态性能。2.系统仿真结果 (完整程序运行后无水印) 3.核心程序与模型 版本:MATLAB2022a 4.系统原理简介 4.1 无…

第十课 从人类反馈中引导强化学习

GPT-1GPT-2(至少要三个支持是因为网络上的垃圾信息很多,有了支持能够显著减少垃圾信息的量)GPT-2首次实现了零样本学习。零样本学习是指模型在从未接触过特定任务的训练数据 、无需额外示例 、无需调整参数(梯度更新)的情况下,直接完成任务的能力。例如,用户只需给模型一…

Olive直播管理系统

在校园教学与在线教育场景中,师生对实时音视频传输的需求日益增长。传统直播工具往往缺乏定制化功能,且难以满足多平台流分发、低延迟交互等教育场景的特殊需求。因此,本软件旨在打造一款轻量级、高稳定性的直播管理工具,专注于解决以下问题:简化直播流程:教师可快速搭建…

Redis--Lesson05--Redis进阶

一.Redis中的事务 在Redis中,单条命令依旧保持原子性,但是对于事务来说(命令集)不保证原子性 Redis事务的本质:一组命令的集合,一个事务中所有的命令都会被序列化,在事务的执行过程中,会按照顺序执行,一次性,顺序性,排他性!执行一些命令 如:--- 队列 set1,set2,…

基于入侵野草算法的KNN分类优化matlab仿真

1.程序功能描述 基于入侵野草算法的KNN分类优化。其中,入侵野草算法是一种启发式优化算法,它模拟了自然界中野草的扩散与竞争过程。该算法通过一系列的步骤来寻找样板的最优特征,参与KNN的分类训练和测试。 2.测试软件版本以及运行结果展示MATLAB2022A版本运行 (完…