当前位置: 首页 > article >正文

FastAPI 进阶:使用 Pydantic 验证器增强 Query 参数验证

在 FastAPI 中,为 Query 类参数添加更复杂的验证逻辑可以通过以下几种方法实现:

  1. 使用 Pydantic 验证器
    Pydantic 允许你在模型中定义自定义验证器。这些验证器可以用于 Query 参数,以实现复杂的验证逻辑。

    from fastapi import FastAPI, Query, Depends, HTTPException
    from pydantic import BaseModel, validator
    
    app = FastAPI()
    
    class QueryParameters(BaseModel):
        q: str
    
        @validator('q')
        def check_custom_logic(cls, value):
            # 这里可以添加任何复杂的逻辑
            if 'forbidden' in value:
                raise ValueError('The value is not allowed')
            return value
    
    @app.get("/items/")
    async def read_items(q: QueryParameters = Depends()):
        return {"q": q.q}
    
  2. 使用前置依赖函数
    通过在路由函数中使用 Depends,你可以创建一个前置依赖函数来执行复杂的验证逻辑。

    from fastapi import FastAPI, Depends, Query, HTTPException
    
    app = FastAPI()
    
    def complex_query_validator(query: str):
        if not query.startswith("allowed_"):
            raise HTTPException(status_code=400, detail="Query parameter does not follow the rules")
        return query
    
    @app.get("/items/")
    async def read_items(q: str = Depends(complex_query_validator)):
        return {"q": q}
    
  3. 使用正则表达式
    Query 类支持 regex 参数,你可以使用它来定义一个正则表达式,用于验证查询参数的格式。

    from fastapi import FastAPI, Query
    
    app = FastAPI()
    
    @app.get("/items/")
    async def read_items(q: str = Query(..., regex="^[a-zA-Z0-9]+$")):
        return {"q": q}
    
  4. 组合使用 Query 参数
    你可以组合使用多个 Query 参数,并在路由函数中实现逻辑来验证这些参数的组合。

    from fastapi import FastAPI, Query
    
    app = FastAPI()
    
    @app.get("/items/")
    async def read_items(min_price: float = Query(gt=0), max_price: float = Query(gt=0)):
        if min_price >= max_price:
            raise ValueError("min_price should be less than max_price")
        return {"min_price": min_price, "max_price": max_price}
    
  5. 使用自定义依赖项类
    你可以创建自定义的依赖项类,这些类继承自 Depends 并实现 __call__ 方法,以封装复杂的验证逻辑。

    from fastapi import FastAPI, Depends, Query
    
    app = FastAPI()
    
    class CustomQuery:
        def __call__(self, query: str):
            if not query.isalpha():
                raise ValueError("Query must contain only letters")
            return query
    
    @app.get("/items/")
    async def read_items(q: str = Depends(CustomQuery())):
        return {"q": q}
    
  6. 使用外部库
    如果需要,你可以使用外部验证库(如 Marshmallow Cerberus)来实现复杂的验证逻辑,并将验证结果作为依赖项注入路由函数。

通过这些方法,你可以为 FastAPI 应用中的 Query 类参数添加几乎任何复杂度的验证逻辑,确保输入数据的准确性和安全性。

在 FastAPI 应用中,为 Query 参数编写 Pydantic 验证器可以让你实现复杂的验证逻辑。以下是如何为 Query 参数创建和使用 Pydantic 验证器的步骤:

  1. 定义 Pydantic 模型
    创建一个 Pydantic 模型,并在模型中定义你的 Query 参数以及相应的验证器。

  2. 编写验证器
    使用模型中的 @validator 装饰器来创建一个验证器函数,该函数将包含你的验证逻辑。

  3. 使用依赖注入
    在路由函数中,使用 Depends 来注入你的模型实例,这样 FastAPI 就会在调用路由函数之前执行验证逻辑。

下面是一个示例代码,展示了如何为 Query 参数编写 Pydantic 验证器:

from fastapi import FastAPI, Depends, Query
from pydantic import BaseModel, Field, validator
from typing import Union, Optional

app = FastAPI()

# 定义 Pydantic 模型
class QueryParameters(BaseModel):
    q: Optional[str] = None
    size: Optional[int] = Query(default=None, gt=0)

    # 验证器,确保 'q' 参数不为空,且 'size' 大于 0
    @validator('q', pre=True, always=True)
    def check_q_not_empty(cls, v):
        if v is None or v == "":
            raise ValueError("Query parameter 'q' cannot be empty")
        return v

    @validator('size', pre=True, allow_reuse=True)
    def check_size_positive(cls, v):
        if v is not None and v <= 0:
            raise ValueError("Query parameter 'size' must be greater than 0")
        return v

# 依赖项函数,返回验证后的 QueryParameters 实例
def validate_query_params(params: QueryParameters = Depends()):
    return params

# 路由函数
@app.get("/items/")
async def read_items(query_params: QueryParameters = Depends(validate_query_params)):
    results = {"q": query_params.q, "size": query_params.size}
    return results

在这个例子中:

  • QueryParameters 类定义了两个查询参数 qsize
  • check_q_not_empty 验证器确保 q 参数不为空。
  • check_size_positive 验证器确保 size 参数大于 0。
  • validate_query_params 函数作为依赖项,它使用 Depends 注解来注入 QueryParameters 实例。
  • 在路由函数 read_items 中,我们通过依赖项注入获取验证后的参数。

当请求到达 /items/ 路由时,FastAPI 会首先调用 validate_query_params 函数来验证查询参数,如果验证失败,它会返回错误响应。如果验证成功,路由函数将接收到验证后的参数值。


http://www.kler.cn/a/288177.html

相关文章:

  • 选择器css
  • 数据结构-二叉树的遍历和线索二叉树
  • 《C++打造高效网络爬虫:突破数据壁垒》
  • CentOS全面停服,国产化提速,央国企信创即时通讯/协同门户如何选型?
  • 技术指南:5分钟零成本实现本地AI知识库搭建
  • 论文笔记: Boosting Object Detection with Zero-Shot Day-Night Domain Adaptation
  • 力扣229题详解:求众数 II 的多种解法与模拟面试问答
  • ELK日志服务收集SpringBoot日志案例
  • 【每日刷题】Day106
  • CentOS 安装 NVIDIA 相关软件包时出现依赖问题
  • 四层神经网络,反向传播计算过程;四层神经网络中:y的函数公式是什么
  • MySQL的事务认识
  • 传输层(TCP、UDP、RDT详解)
  • 视频智能分析打手机检测算法安防监控打手机检测算法应用场景、算法源码、算法模型介绍
  • 计算机网络(一) —— 网络基础入门
  • JavaScript 在 VSCode 中的开发体验
  • 【数据结构】二叉搜索树的功能实现详解
  • 无人机之发动机篇
  • 谷歌的 GameNGen:无需游戏引擎,人工智能模拟 “毁灭战士“,开辟新天地
  • 24.9.1(康托展开)
  • 构建高可用的微服务架构:Spring Cloud Consul与负载均衡