SR-303:它是一项 Bean Validation 校验标准,规定了一些校验规范,比如@Null,@NotNull,@Pattern,相关注解都位于javax.validation.constraints包下。需要注意的是,[JSR-303]只提供校验规范,不提供实现。
而在 Spring 中,其也提供了相应的 Bean Validation 实现:Java Bean Validation。
一、添加依赖
1 | <dependency> |
字符串/数组/集合检查:(字符串本身就是个数组)
@Pattern(regexp=”reg”) 验证字符串满足正则
@Size(max, min) 验证字符串、数组、集合长度范围
@NotEmpty 验证字符串不为空或者null
@NotBlank 验证字符串不为null或者trim()后不为空
数值检查:同时能验证一个字符串是否是满足限制的数字的字符串
@Max 规定值得上限int
@Min 规定值得下限
@DecimalMax(“10.8”) 以传入字符串构建一个BigDecimal,规定值要小于这个值
@DecimalMin 可以用来限制浮点数大小
@Digits(int1, int2) 限制一个小数,整数精度小于int1;小数部分精度小于int2
@Digits 无参数,验证字符串是否合法
@Range(min=long1,max=long2) 检查数字是否在范围之间
这些都包括边界值
日期检查:Date/Calendar
@Post 限定一个日期,日期必须是过去的日期
@Future 限定一个日期,日期必须是未来的日期
其他验证:
@Vaild 递归验证,用于对象、数组和集合,会对对象的元素、数组的元素进行一一校验
@Email 用于验证一个字符串是否是一个合法的右键地址,空字符串或null算验证通过
@URL(protocol=,host=,port=,regexp=,flags=) 用于校验一个字符串是否是合法URL
二、MethodArgumentNotValidException异常
MethodArgumentNotValidException(@Validated @Valid 前端提交的方式为json格式有效,出现异常时会被该异常类处理)
2022-06-25 15:52:31.070 WARN 4244 — [nio-8081-exec-2] .m.m.a.ExceptionHandlerExceptionResolver : Resolved [org.springframework.web.bind.MethodArgumentNotValidException: Validation failed for argument [0] in public com.example.testspringboot.domain.User com.example.testspringboot.controller.HelloController.validataedTest(com.example.testspringboot.domain.User): [Field error in object ‘user’ on field ‘password’: rejected value [1]; codes [Length.user.password,Length.password,Length.java.lang.String,Length]; arguments [org.springframework.context.support.DefaultMessageSourceResolvable: codes [user.password,password]; arguments []; default message [password],6,3]; default message [pwd需要3-6位]] ]
以上参数:
objectName - 受影响对象的名称
code- 用于解决此消息的代码
arguments - 用于解析此消息的参数数组
defaultMessage - 用于解析此消息的默认消息
三、示例
1 | package com.example.testspringboot.domain; |