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

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

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

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

  • 相关阅读:
    Flex4之关于Embed外部资源的使用方法总结
    Flex tree的开发 后台数据连接
    Flex4之Tree开发
    Flex自定义组件开发
    解决AS3请求数据的“安全沙箱冲突”问题
    purMVC代码备份
    译:如何配置Red5应用程序
    关于RED5——配置文件详解
    关于socket使用Amf直接进行对象传输的
    垃圾回收机制
  • 原文地址:https://www.cnblogs.com/mazhiyong/p/13072728.html
Copyright © 2011-2022 走看看