FastAPI(32)- Dependencies in path operation 通过路径操作装饰器的 dependencies 参数声明依赖

简介: FastAPI(32)- Dependencies in path operation 通过路径操作装饰器的 dependencies 参数声明依赖

背景


  • 在某些实际场景中,并不需要使用依赖项的返回值,或者依赖项没有返回值,但仍需要执行这个依赖项
  • 针对这种场景,可以向路径操作装饰器的 dependencies 参数传入依赖项,而不使用 Depends()

 

dependences 参数


image.png

  • dependences 类型指定为 Optional[Sequence[Depends]]
  • Sequence 是序列,不仅可以接收 List,还可以接收 Set、Tuple 等
  • 子类型就是 Depends

 

实际栗子


#!usr/bin/env python
# -*- coding:utf-8 _*-
"""
# author: 小菠萝测试笔记
# blog:  https://www.cnblogs.com/poloyy/
# time: 2021/9/25 12:52 下午
# file: 28_path_depends.py
"""
from typing import Optional
import uvicorn
from fastapi import Depends, FastAPI, HTTPException, Header
app = FastAPI()
# 1、第一个依赖,验证请求头中的 x_token
async def verify_token(x_token: str = Header(...)):
    if x_token != "fake-super-secret-token":
        # 验证失败,则抛出异常
        raise HTTPException(status_code=400, detail="X-Token header invalid")
    # 没有 return
# 2、第二个依赖,验证请求头中的 x_key
async def verify_key(x_key: str = Header(...)):
    if x_key != "fake-super-secret-key":
        # 验证失败,则抛出异常
        raise HTTPException(status_code=400, detail="X-Key header invalid")
    # 有 return
    return x_key
@app.get("/items",
         dependencies=[
             # 声明了两个依赖,是一个数组哦
             Depends(verify_token),
             Depends(verify_key)]
         )
async def read_item():
    return [{"item": "Foo"}, {"item": "Bar"}]
if __name__ == "__main__":
    uvicorn.run(app="28_path_depends:app", host="127.0.0.1", port=8080, reload=True, debug=True) 


  • 虽然第二个依赖项有 return 值,但是并不会传递给路径操作函数,所以 return 不 return 没什么区别
  • 即使不使用依赖项的 return 值,该依赖项仍然会被调用

 

重点总结

@app.get("/items/", dependencies=[Depends(verify_token), Depends(verify_key)])

通过路径操作装饰器的 dependences 参数声明依赖,并不会使用依赖项的返回值

 

async def read_query(query_or_default: str = Depends(query_or_cookie_extractor)):

   pass

通过函数参数来声明依赖,会将依赖项的返回值赋值给参数使用

 

查看 Swagger API 文档

image.png


正确传参的请求结果

image.png

依赖项校验失败的请求结果

image.png

相关文章
|
数据采集 JSON JavaScript
全面拥抱FastApi —三大参数及验证
全面拥抱FastApi —三大参数及验证
|
4月前
|
开发框架 JSON API
Python中FastAPI项目使用 Annotated的参数设计
Python中FastAPI项目使用 Annotated的参数设计
|
7月前
|
Python
Fastapi进阶用法,路径参数,路由分发,查询参数等详解
Fastapi进阶用法,路径参数,路由分发,查询参数等详解
447 1
|
网络安全 Windows
基于fastapi实现6个接口(token拦截, 2个业务流程,接口参数依赖校验)已经通过postman测试,记录部署服务器和windows,用于pytest接口自动化框架的接口测试对象
基于fastapi实现6个接口(token拦截, 2个业务流程,接口参数依赖校验)已经通过postman测试,记录部署服务器和windows,用于pytest接口自动化框架的接口测试对象
|
前端开发 中间件 API
FastAPI第二天---参数校验
FastAPI第二天---参数校验
242 0
FastAPI第二天---参数校验
|
NoSQL 测试技术 Redis
FastAPI(八十四)实战开发《在线课程学习系统》--接口测试(下)
FastAPI(八十四)实战开发《在线课程学习系统》--接口测试(下)
FastAPI(八十四)实战开发《在线课程学习系统》--接口测试(下)
|
存储 测试技术 数据安全/隐私保护
FastAPI(八十三)实战开发《在线课程学习系统》--注册接口单元测试
FastAPI(八十三)实战开发《在线课程学习系统》--注册接口单元测试
FastAPI(八十三)实战开发《在线课程学习系统》--注册接口单元测试
|
测试技术 数据安全/隐私保护
FastAPI(八十四)实战开发《在线课程学习系统》--接口测试(上)
FastAPI(八十四)实战开发《在线课程学习系统》--接口测试(上)
FastAPI(八十二)实战开发《在线课程学习系统》接口开发-- 课程上架下架
FastAPI(八十二)实战开发《在线课程学习系统》接口开发-- 课程上架下架
|
NoSQL Redis 数据库
FastAPI(八十一)实战开发《在线课程学习系统》接口开发-- 推荐课程列表与课程点赞
FastAPI(八十一)实战开发《在线课程学习系统》接口开发-- 推荐课程列表与课程点赞