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

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

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

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

  • 相关阅读:
    DS博客作业03--树
    C博客作业05--指针
    C博客作业04--数组
    C博客作业03--函数
    C博客作业02--循环结构
    顺序分支结构
    我的第一篇博客
    第1次任务:购物车程序的面向对象设计
    5-互评-OO之接口-DAO模式代码阅读及应用
    第三周-面向对象基础与类的识别-自主学习任务
  • 原文地址:https://www.cnblogs.com/mazhiyong/p/13072728.html
Copyright © 2011-2022 走看看