zoukankan      html  css  js  c++  java
  • 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"}]

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

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

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

  • 相关阅读:
    C++分数类
    2019 SDN大作业
    个人作业-软工实践总结
    2019 SDN上机第7次作业
    2019 SDN上机第6次作业
    2019 SDN课程阅读作业(2)
    个人作业--软件评测
    2019 SDN上机第5次作业
    2019 SDN上机第4次作业
    2019 SDN第一次阅读作业
  • 原文地址:https://www.cnblogs.com/mazhiyong/p/13072728.html
Copyright © 2011-2022 走看看