二. 常见注解及使用场景介绍
限制 说明
@Null 限制只能为null
@NotNull 限制必须不为null
@AssertFalse 限制必须为false
@AssertTrue 限制必须为true
@DecimalMax(value) 限制必须为一个不大于指定值的数字
@DecimalMin(value) 限制必须为一个不小于指定值的数字
@Digits(integer,fraction) 限制必须为一个小数,且整数部分的位数不能超过integer,小数部分的位数不能超过fraction
@Future 限制必须是一个将来的日期,变量类型为Date
@Max(value) 限制必须为一个不大于指定值的数字
@Min(value) 限制必须为一个不小于指定值的数字
@Past 限制必须是一个过去的日期,变量类型为Date
@Pattern(value) 限制必须符合指定的正则表达式
@Size(max,min) 限制字符长度必须在min到max之间
@NotEmpty 验证注解的元素值不为null且不为空(字符串长度不为0、集合大小不为0)
@NotBlank 验证注解的元素值不为空(不为null、去除首位空格后长度为0),不同于@NotEmpty,@NotBlank只应用于字符串且在比较时会去除字符串的空格
@Email 验证注解的元素值是Email,也可以通过正则表达式和flag指定自定义的email格式
public class ValidatorController {
@RequestMapping("/validator")
public String testValidator(@RequestBody @ValidDemoModel demoModel,BindingResult bindingResult) { //这里BindingResult参数必须紧跟被@Valid注解的参数
if (bindingResult.hasErrors()) {
StringBuffer message = new StringBuffer();
List<ObjectError>allErrors = bindingResult.getAllErrors();
for (ObjectError oneError : allErrors) {
message.append(oneError.getDefaultMessage()).append(";");
}
return message.toString();
} else {
return "请求成功,参数校验通过";
}
}
}