FastAPI 学习之路(二十四)子依赖项

FastAPI 支持创建含子依赖项的依赖项。并且,可以按需声明任意深度的子依赖项嵌套层级。

    FastAPI 负责处理解析不同深度的子依赖项。

    我们去实现一个简单的demo

复制代码
from fastapi import Depends, FastAPI
from  typing import Optional
app = FastAPI()
fake_items_db = [{"city": "beijing"}, {"city": "shanghai"},
                 {"city": "heze"}]

def query_extractor(desc: Optional[str] = None):
    return desc
def query__extractor(
    desc: str = Depends(query_extractor),
        name: Optional[str]="" ,
):
    if not desc:
        return name
    return desc
@app.get("/items/")
def read_items(query__extractor: str = Depends(query__extractor)):

    return query__extractor
复制代码

我们去看下接口请求

 

 

 

 

我们可以看到,我们实现的子依赖是成功的。

 

    • 尽管该函数自身是依赖项,但还声明了另一个依赖项(它「依赖」于其他对象)

      • 该函数依赖 query_extractor, 并把 query_extractor 

        的返回值赋给参数 desc

    • 同时,该函数还声明了类型是 str 的可选name

用户未提供desc 时,则使用name

 

多次使用同一个依赖项

    • 如果在同一个路径操作 多次声明了同一个依赖项,例如,多个依赖项共用一个子依赖项,FastAPI 在处理同一请求时,只调用一次该子依赖项。

    • FastAPI 不会为同一个请求多次调用同一个依赖项,而是把依赖项的返回值进行「缓存」,并把它传递给同一请求中所有需要使用该返回值的「依赖项」。

       

    

    其实依赖注入系统非常简单。

    依赖注入无非是与路径操作函数一样的函数罢了。

    但它依然非常强大,能够声明任意嵌套深度的「图」或树状的依赖结构。

文章首发在公众号,欢迎关注。

posted @   北漂的雷子  阅读(298)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
点击右上角即可分享
微信分享提示