1. 引言
从Spring 3.0开始,Spring MVC中提供了对Java校验API(Java Validation API,又称JSR-303)的支持,从而避免了逻辑代码弄乱处理器的方法。
2. 校验注解
这些注解可以放在属性上,从而限制这些属性的值,所有的注解都位于javax.validation.constraints包中。
注 解 | 描 述 |
---|---|
@AssertFalse | 所注解的元素必须是Boolean类型,并且为false |
@AssertTrue | 所注解的元素必须是Boolean类型,并且为true |
@DecimalMax | 所注解的元素必须是数字,并且他的值要小于或等于给定的BigDecimalString值 |
@DecimalMin | 所注解的元素必须是数字,并且他的值要大于或等于给定的BigDecimalString值 |
@Digits | 所注解的元素必须是数字,并且他的值必须有制定的位数 |
@Future | 所注解的值必须是一个将来的日期 |
@Max | 所注解的元素必须是数字,并且他的值要小于或等于给定的值 |
@Min | 所注解是元素必须是数字,并且他的值要大于或等于给定的值 |
@NotNull | 所注解的元素必须不为null |
@Null | 所注解的元素必须为null |
@Past | 所注解的元素必须为一个已过去的日期 |
@Pattern | 所注解的元素必须匹配给定的正则表达式 |
@Size | 所注解的元素必须为String、集合或数组,并且他的长度符合给定的范围 |
示例代码如下:
public class Demo{
@NotNull
@Size(min=5, max=16)
private String username;
...
}
3. 在控制器中验证对象
在控制器中验证对象的方法是在对象前添加@Valid注解,代码如下
@RequestMapping(value="/register", method=RequestMethod.POST)
public String processRegistration(
@Valid Demo demo,
Errors error
){
//判断是否有错误并处理
if(error.hasErrors()){
...
}
....
}
Demo对象添加了@Valid注解,这会告诉Spring,需要确保这个对象满足校验限制。但是在Demo属性上添加校验限制并不能阻止表单提交,只能通过error.hasErrors()方法判断错误并处理。
需要注意的是,@Valid注解所标注的检验参数后要紧跟着Errors参数,错误都可以通过Errors对象访问
4. 需要的包
gradle包依赖:
compile group: ‘javax.validation’, name: ‘validation-api’, version: ‘1.1.0.Final’
compile group: ‘org.hibernate’, name: ‘hibernate-validator’, version: ‘5.0.1.Final’