本文最后更新于41 天前,其中的信息可能已经过时,如有错误请发送邮件到big_fw@foxmail.com
1、中间件
- 中间件:是一个在每次请求进入Fastapi应用时都会被执行的函数。
- 它在请求到达实际的路径操作(处理函数)之前运行,并且在响应返回客户端之前再运行一次。
- 中间件的作用:为每一个请求添加统一的处理逻辑如:(日志记录、身份认证、跨域处理、响应头处理、性能监控等)

#中间件:自下而上执行先2后1
@app.middleware("http")
async def middleware1(request, call_next):
print("中间件1开始执行")
reponse = await call_next(request)
print("中间件1结束执行")
return reponse
@app.middleware("http")
async def middleware2(request, call_next):
print("中间件2开始执行")
reponse = await call_next(request)
print("中间件2结束执行")
return reponse
2、依赖注入系统
- 作用:使用依赖注入系统来共享通用逻辑,减少代码冲突。
- 注意:控制所有请求都有的通用代码用中间件,想要指定哪些接口需要用依赖注入。
- 场景:处理请求参数、共享业务逻辑、共享数据库连接、安全和认证。

# 分页参数逻辑共用: 新闻列表和用户列表
# 1、创建依赖项
# 2、导入Depends:from fastapi import FastAPI, Path, Query, HTTPException, Depends
async def common_parameters(
skip: int = Query(0, ge=0),
limit: int = Query(10, ge=1, le=100)
):
return {"skip": skip, "limit": limit}
# 3、声明依赖项
# 需要注入分页参数逻辑
@app.get("/news/news_list")
async def get_news_list(commons=Depends(common_parameters)):
return commons
# 需要注入分页参数逻辑
@app.get("/user/user_list")
async def get_user_list(commons=Depends(common_parameters)):
return commons

