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

FastAPI中的依赖注入详解与示例

在构建现代Web应用时,代码的模块化和复用性至关重要。FastAPI内置了强大的依赖注入(Dependency Injection,简称DI)系统,帮助开发者轻松管理和复用复杂的逻辑、参数和服务,如数据库连接、认证、配置等。本文将详细介绍FastAPI依赖注入的原理、使用方法,并通过代码示例帮助你快速掌握。

什么是依赖注入?

依赖注入是一种设计模式,通过将组件所依赖的对象(依赖项)由外部传入,而不是在组件内部自行创建,从而实现代码解耦和复用。在FastAPI中,依赖注入允许我们声明路径操作函数所需的依赖,FastAPI会自动执行依赖逻辑并将结果注入到函数参数中。

FastAPI依赖注入的基本用法

1. 定义依赖项函数

依赖项通常是一个普通函数(可以是异步的),它执行某些逻辑并返回需要注入的值。例如,一个处理查询参数的依赖项:

from typing import Union
from fastapi import Depends, FastAPIapp = FastAPI()async def common_parameters(q: Union[str, None] = None, skip: int = 0, limit: int = 100
):return {"q": q, "skip": skip, "limit": limit}

2. 在路径操作函数中声明依赖

通过Depends将依赖函数注入到路径操作函数的参数中:

@app.get("/items/")
async def read_items(commons: dict = Depends(common_parameters)):return commons@app.get("/users/")
async def read_users(commons: dict = Depends(common_parameters)):return commons

当请求/items//users/时,FastAPI会先调用common_parameters函数,获取返回值并赋给commons参数,然后执行路径操作函数。

依赖注入的工作流程

  • FastAPI识别路径操作函数参数中使用的Depends
  • 自动调用依赖函数,传入请求中的参数(如查询参数)。
  • 获取依赖函数的返回值,并注入到路径操作函数对应参数。
  • 执行路径操作函数,返回响应。

依赖注入的高级用法

1. 类作为依赖项

依赖项不仅限于函数,也可以是类。FastAPI会实例化该类并注入:

from fastapi import Depends, FastAPIapp = FastAPI()class CommonQueryParams:def __init__(self, q: str = None, skip: int = 0, limit: int = 100):self.q = qself.skip = skipself.limit = limit@app.get("/items/")
async def read_items(commons: CommonQueryParams = Depends(CommonQueryParams)):return {"q": commons.q, "skip": commons.skip, "limit": commons.limit}

这种方式适合依赖项需要维护状态或多个方法的场景。

2. 依赖项嵌套(子依赖)

依赖项函数可以依赖其他依赖项,实现复杂逻辑拆分。例如:

from fastapi import Dependsasync def get_token_header(token: str = Depends(oauth2_scheme)):# 验证token逻辑return tokenasync def get_current_user(token: str = Depends(get_token_header)):# 根据token获取用户return user

3. 依赖项的生命周期管理

依赖函数可以用yield关键字实现上下文管理,完成资源的初始化和清理,如数据库连接:

from fastapi import Dependsasync def get_db():db = create_db_session()try:yield dbfinally:db.close()@app.get("/items/")
async def read_items(db = Depends(get_db)):items = db.query(...)return items

依赖注入的优势

  • 代码复用:将通用逻辑封装为依赖项,多个路径操作函数共享。
  • 解耦合:路径操作函数无需关心依赖的创建细节。
  • 自动验证:依赖项参数支持类型注解,FastAPI自动校验请求参数。
  • 灵活性:支持同步和异步依赖,类和函数均可作为依赖。
  • 集成方便:轻松集成数据库连接、认证、配置等服务。

完整示例代码

from typing import Union
from fastapi import Depends, FastAPIapp = FastAPI()# 依赖项函数,处理查询参数
async def common_parameters(q: Union[str, None] = None, skip: int = 0, limit: int = 100
):return {"q": q, "skip": skip, "limit": limit}# 路径操作函数,注入依赖
@app.get("/items/")
async def read_items(commons: dict = Depends(common_parameters)):return commons# 类作为依赖项示例
class CommonQueryParams:def __init__(self, q: Union[str, None] = None, skip: int = 0, limit: int = 100):self.q = qself.skip = skipself.limit = limit@app.get("/users/")
async def read_users(commons: CommonQueryParams = Depends(CommonQueryParams)):return {"q": commons.q, "skip": commons.skip, "limit": commons.limit}

运行后访问/items//users/,可以通过查询参数传入qskiplimit,FastAPI会自动调用依赖项并注入参数。

通过上述介绍和示例,你可以看到FastAPI的依赖注入系统设计简洁且功能强大,能够帮助你构建模块化、易维护的高性能API应用。掌握依赖注入,是提升FastAPI开发效率和代码质量的重要一步。

相关文章:

  • MLLM之Bench:LEGO-Puzzles的简介、安装和使用方法、案例应用之详细攻略
  • 语音合成之八-情感化语音合成的演进路线
  • HTTP header Cookie 和 Set-Cookie
  • DIFY教程第一集:安装Dify配置环境
  • 泰迪杯实战案例超深度解析:旅游景点游客流量预测与资源优化
  • 英文中日期读法
  • 记录学习记录学习《手动学习深度学习》这本书的笔记(九)
  • Python中的Walrus运算符分析
  • 第35课 常用快捷操作——用“鼠标左键”拖动图元
  • 产品经理面经(1)
  • 在winform中使用chromiumWebBrowser显示Echarts图表
  • 前端高频面试题day2
  • 大模型工程师基础之学会使用openai
  • 51单片机所有寄存器介绍
  • leetcode0103. 二叉树的锯齿形层序遍历-medium
  • JAVA手写题-精通 Java 单例模式:三种线程安全的实现方式详解
  • JAVA:单例模式
  • 【锂电池剩余寿命预测】Transformer锂电池剩余寿命预测(Pytorch完整源码和数据)
  • Java : GUI
  • RC吸收电路参数设置实战
  • 国家能源局:支持民营企业参股投资核电项目
  • 修订占比近30%收录25万条目,第三版《英汉大词典》来了
  • 新任浙江省委常委、杭州市委书记刘非开展循迹溯源学习调研
  • 安徽一交通事故责任认定引质疑:民警和司法鉴定人被处罚,已中止诉讼
  • 政治局会议:根据形势变化及时推出增量储备政策,加强超常规逆周期调节
  • 远程控制、窃密、挖矿!我国境内捕获“银狐”木马病毒变种