Bean Validation & hibernate validation & spring validation 之间的关系

简述 JSR303/JSR-349,hibernate validation,spring validation 之间的关系。JSR303 是一项标准,JSR-349 是其的升级版本,添加了一些新特性,他们规定一些校验规范即校验注解,如 @Null,@NotNull,@Pattern,他们位于 javax.validation.constraints 包下,只提供规范不提供实现。而 hibernate validation 是对这个规范的实践(不要将 hibernate 和数据库 orm 框架联系在一起),他提供了相应的实现,并增加了一些其他校验注解,如 @Email,@Length,@Range 等等,他们位于 org.hibernate.validator.constraints 包下。而万能的 spring 为了给开发者提供便捷,对 hibernate validation 进行了二次封装,显示校验 validated bean 时,你可以使用 spring validation 或者 hibernate validation,而 spring validation 另一个特性,便是其在 springmvc 模块中添加了自动校验,并将校验信息封装进了特定的类中。这无疑便捷了我们的 web 开发。

  • Bean Validation 是标准
  • hibernate validation 是实现
  • spring validation 对hibernate validation进行了二次封装


image.png**

Error对象

image.png

Validator

image.png

@Validated原理

MethodValidationPostProcessor来处理Bean,使用aop增强。
image.png
image.png
顾名思义,对Bean中的方法的验证。

@Validated和@Valid区别

在检验Controller的入参是否符合规范时,使用@Validated或者@Valid在基本验证功能上没有太多区别。但是在分组、注解地方、嵌套验证等功能上两个有所不同

  1. 注解位置
    • @Validated:用在类型、方法和方法参数上。但不能用于成员属性(field)
    • @Valid:可以用在方法、构造函数、方法参数和成员属性(field)上
  2. 分组校验
    • @Validated:提供分组功能,可以在参数验证时,根据不同的分组采用不同的验证机制
    • @Valid:没有分组功能
  3. 嵌套校验
    • 成员上用 @Valid

@Validated和@Valid区别:Spring validation验证框架对入参实体进行嵌套验证必须在相应属性(字段)加上@Valid而不是@Validated - 花郎徒结的博客 - CSDN博客

参数校验条件

  1. 被@Validated注解标注
  2. 或被@valid开头的注解标注

image.png

@size不能约束null

要配合@NotEnpty

校验异常处理

语雀内容