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"}]

这些依赖项与普通依赖项的执行相同,但他们的返回值(如果有)不会被传递给路径操作函数。

我们可以重复使用已经声明的依赖项,无论他们是否有返回值,都不会影响依赖项的执行。

 

注意:依赖项的执行顺序与列表里的排列顺序相同。

 

posted on 2020-06-09 15:09  麦克煎蛋  阅读(1470)  评论(0编辑  收藏  举报