@Validated和@Valid有什么不同呢?
下文笔者讲述@Validated和@Valid的区别说明,如下所示
Spring Validation验证框架对参数的验证机制提供了@Validated(Spring’s JSR-303规范,是标准JSR-303的一个变种) javax提供了@Valid(标准JSR-303规范),配合BindingResult可以直接提供参数验证结果
JSR303定义的校验类型
空检查 | |
@Null | 验证对象是否为null |
@NotNull | 验证对象是否不为null, 无法查检长度为0的字符串 |
@NotBlank | 检查约束字符串是不是Null还有被Trim的长度是否大于0,只对字符串,且会去掉前后空格 |
@NotEmpty | 检查约束元素是否为NULL或者是EMPTY |
Booelan检查 | |
@AssertTrue | 验证 Boolean 对象是否为 true |
@AssertFalse | 验证 Boolean 对象是否为 false |
长度检查 | |
@Size(min=, max=) | 验证对象(Array,Collection,Map,String)长度是否在给定的范围之内 |
@Length(min=, max=) | 验证注解的元素值长度在min和max区间内 |
日期检查 | |
@Past | 验证 Date 和 Calendar 对象是否在当前时间之前 |
@Future | 验证 Date 和 Calendar 对象是否在当前时间之后 |
@Pattern | 验证 String 对象是否符合正则表达式的规则 |
数值检查,建议使用在Stirng,Integer类型,不建议使用在int类型上,因为表单值为“”时无法转换为int,但可以转换为Stirng为"",Integer为null | |
@Min | 验证 Number 和 String 对象是否大等于指定的值 |
@Max | 验证 Number 和 String 对象是否小等于指定的值 |
@DecimalMax | 被标注的值必须不大于约束中指定的最大值. 这个约束的参数是一个通过BigDecimal定义的最大值的字符串表示.小数存在精度 |
@DecimalMin | 被标注的值必须不小于约束中指定的最小值. 这个约束的参数是一个通过BigDecimal定义的最小值的字符串表示.小数存在精度 |
@Digits | 验证 Number 和 String 的构成是否合法 |
@Digits(integer=,fraction=) | 验证字符串是否是符合指定格式的数字,interger指定整数精度,fraction指定小数精度 |
@Range(min=, max=) | 验证注解的元素值在最小值和最大值之间 |
@Range(min=10000,max=50000,message="range.bean.wage") private BigDecimal wage; | |
@Valid 递归的对关联对象进行校验, 如果关联对象是个集合或者数组,那么对其中的元素进行递归校验,如果是一个map,则对其中的值部分进行校验.(是否进行递归验证) | |
@CreditCardNumber | 信用卡验证 |
验证是否是邮件地址,如果为null,不进行验证,算通过验证 | |
@ScriptAssert(lang= ,script=, alias=) | |
@URL(protocol=,host=, port=,regexp=, flags=) |
@Validated和@Valid区别
在检验入参是否符合规范时 使用@Validated或者@Valid在基本验证功能上没有太多区别 但在分组、注解地方、嵌套验证等功能上两个有所不同
1.分组
@Validated: 提供了一个分组功能 可以在入参验证时 根据不同的分组采用不同的验证机制 没有添加分组属性时 默认验证没有分组的验证属性 代码如下 public interface First{ } public interface Second{ } public class UserModel { @NotNull(message = "{id.empty}", groups = { First.class }) private int id; @NotNull(message = "{username.empty}", groups = { First.class, Second.class }) private String username; @NotNull(message = "{content.empty}", groups = { First.class, Second.class }) private String content; } public String save(@Validated( { Second.class }) UserModel userModel, BindingResult result) { if (result.hasErrors()) { return "validate/error"; } return "redirect:/success"; } 对一个参数需要多种验证方式时,也可通过分配不同的组达到目的 例: @NotEmpty(groups = { First.class }) @Size(min = 3, max = 8, groups = { Second.class }) private String name; @Valid: 作为标准JSR-303规范 还没有吸收分组的功能
2.注解地方
@Validated 可用在类型、方法和方法参数上 但是不能用在成员属性(字段)上 @Valid 可用在方法、构造函数、方法参数和成员属性(字段)上 两者是否能用于成员属性(字段)上直接影响能否提供嵌套验证的功能。
3.嵌套验证
public class TestItem { @NotNull(message = "id不能为空") @Min(value = 1, message = "id必须为正整数") private Long id; @Valid // 嵌套验证必须用@Valid @NotNull(message = "other不能为空") @Size(min = 1, message = "至少要有一个属性") private list<Other> other; } public class Other { @NotNull(message = "pid不能为空") @Min(value = 1, message = "pid必须为正整数") private Long pid; @NotNull(message = "vid不能为空") @Min(value = 1, message = "vid必须为正整数") private Long vid; @NotBlank(message = "pidName不能为空") private String pidName; @NotBlank(message = "vidName不能为空") private String vidName; } @RestController public class ItemController { @RequestMapping("/item/add") public void addItem(@Validated TestItem testItem, BindingResult bindingResult) { /*业务代码*/ } }
从以上的分析,我们可以得出@Validated和@Valid在嵌套验证功能上的区别: @Validated 在方法入参上无法单独提供嵌套验证功能 不能用在成员属性(字段)上 也无法提示框架进行嵌套验证 能配合嵌套验证注解@Valid进行嵌套验证 @Valid 用在方法入参上无法单独提供嵌套验证功能 能够用在成员属性(字段)上 提示验证框架进行嵌套验证 能配合嵌套验证注解@Valid进行嵌套验证
版权声明
本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。