FastAPI 依赖注入系统(四) 基于路径操作装饰器的依赖项
作者:麦克煎蛋 出处:https://www.cnblogs.com/mazhiyong/ 转载请保留这段声明,谢谢!
在有些情况下,我们并不需要依赖项的返回值,但仍然需要依赖项被执行。
在这种情况下,我们可以通过路径操作装饰器来操作依赖项的一个列表。
通过路径操作装饰器添加依赖项
路径操作装饰器接收一个可选的参数dependencies
,参数内容是Depends()
列表。
from fastapi import Depends, FastAPI, Header, HTTPException app = FastAPI() async def verify_token(x_token: str = Header(...)):
if x_token != "token":
raise HTTPException(status_code=400, detail="X-Token header invalid")
async def verify_key(x_key: str = Header(...)):
if x_key != "key":
raise HTTPException(status_code=400, detail="X-Key header invalid")
return x_key @app.get("/items/", dependencies=[Depends(verify_token), Depends(verify_key)]) async def read_items(): return [{"item": "Foo"}, {"item": "Bar"}]
这些依赖项与普通依赖项的执行相同,但他们的返回值(如果有)不会被传递给路径操作函数。
我们可以重复使用已经声明的依赖项,无论他们是否有返回值,都不会影响依赖项的执行。
注意:依赖项的执行顺序与列表里的排列顺序相同。