目录
2 自定义的curr_page_v参数校验函数,如果不合法抛出自定义异常!
- # 1.用户自定义异常类型,只要该类继承了Exception类即可
- class ValDtoError(Exception):
- # 初始化
- def __init__(self, message):
- self.message = message
-
- # 类一般返回值
- def __str__(self):
- return "参数校验异常!" + self.message
Pydantic提供了四种validator :
BeforeValidator 运行在Pydantic内部的校验转换之前,入参为输入值Any,返回值为Any。
AfterValidator 运行在Pydantic内部的校验转换之后,入参和返回值为正确的字段类型。
PlainValidator 运行时间和BeforeValidator相同,但执行完之后整个校验过程结束,不再执行其他validator和Pydantic内部的校验流程。
WrapValidator 可以运行在pydantic和其他validator之前或者之后,或者返回值、抛出异常立即结束校验流程。
可以使用多个BeforeValidator、AfterValidator和WrapperValidator,但是只能有一个PlainValidator。关于执行顺序,从右到左执行所有Before和Wrap校验器,再从左到右执行所有After校验器
- class CommonPageDto(BaseModel):
- def curr_page_v(v:int) -> int:
- if 111 > v:
- raise ValDtoError('开始页不能小于0!')
- return v
-
- currPage: Annotated[int, BeforeValidator(curr_page_v)]
- pageSize: int
- search: dict
- @app.exception_handler(ValDtoError)
- async def request_validation_exception_handler2(request: Request, exc: ValDtoError):
- print(f"参数校验异常{request.method} {request.url}")
- print(exc)
- return fail_res(f"请求参数为{exc}")