1. 思维脑图
2. 实际操作
第一步:导入相关JAR包
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-validator</artifactId>
<version>6.0.9.Final</version>
</dependency>
第二步:编写javabean,在需要校验的属性上面添加相应的注解
public class User {
@NotEmpty(message = "姓名不能为空")
@Size(min = 4,max = 20,message = "姓名长度必须在{min}-{max}之间")
private String name;
@Min(value = 0, message = "年龄不能小于{value}")
@Max(value = 120,message = "年龄不能大于{value}")
private int age;
@Pattern(regexp = "^1([358][0-9]|4[579]|66|7[0135678]|9[89])[0-9]{8}$", message = "手机号码不正确")
private String phone;
/*
省略setter和getter
*/
}
第三步:修改springmvc.xml配置文件,注册一个验证器,这里使用的是HibernateValidator实现的验证器:
<!--验证器-->
<bean id="beacon1024Validator" class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean">
<property name="providerClass" value="org.hibernate.validator.HibernateValidator"/>
</bean>
<!--注册注解驱动-->
<mvc:annotation-driven validator="beacon1024Validator"/>
第四步:创建controller,在方法的参数中写上User和BindingResult,在User前面添加@Validated注解,
这里需要注意:不能将@Validated 注解在String类型和基本类型的形参前,BindingResult参数可以获取到
所有验证异常的信息,当校验不通过的时候将提示信息放到ModelAndView中传递到jsp里面。
@Controller
@RequestMapping("/user")
public class UserController {
@RequestMapping("/register.do")
//不能将@Validated 注解在String类型和基本类型的形参前。
//BindingResult参数可以获取到所有验证异常的信息
public ModelAndView register(@Validated User user, BindingResult br) {
ModelAndView mv = new ModelAndView();
List<ObjectError> allErrors = br.getAllErrors();
System.out.println(allErrors.size());
if (allErrors != null && allErrors.size() > 0) {
FieldError nameError = br.getFieldError("name");
FieldError ageError = br.getFieldError("age");
FieldError phoneError = br.getFieldError("phone");
if (nameError != null) {
mv.addObject("nameError", nameError.getDefaultMessage());
}
if (ageError != null) {
mv.addObject("ageError", ageError.getDefaultMessage());
}
if (phoneError != null) {
mv.addObject("phoneError", phoneError.getDefaultMessage());
}
mv.setViewName("/register");
return mv;
}
mv.addObject("name", user.getName());
mv.setViewName("/user");
return mv;
}
}
第五步:创建jsp,获取校验信息
<form action="/user/register.do" method="get">
姓名:<input type="text" name="name">${nameError}<br>
年龄:<input type="text" name="age">${ageError}<br>
手机:<input type="text" name="phone">${phoneError}<br>
<input type="submit" value="提交">
</form>
3. Hibernate Validator 中常用的验证注解
@AssertFalse 验证注解的元素值是 false
@AssertTrue 验证注解的元素值是 true
@DecimalMax(value=x) 验证注解的元素值小于等于指定的十进制value 值
@DecimalMin(value=x) 验证注解的元素值大于等于指定的十进制value 值
@Digits(integer=整数位数, fraction=小数位数)验证注解的元素值的整数位数和小数位数上限
@Future 验证注解的元素值(日期类型)比当前时间晚
@Max(value=x) 验证注解的元素值小于等于指定的 value值
@Min(value=x) 验证注解的元素值大于等于指定的 value值
@NotNull 验证注解的元素值不是 null
@Null 验证注解的元素值是 null
@Past 验证注解的元素值(日期类型)比当前时间早
@Pattern(regex=正则表达式) 验证注解的元素值不指定的正则表达式匹配
@Size(min=最小值, max=最大值) 验证注解的元素值的在 min 和 max (包含)指定区间之内,如字符长度、集合大小
@Valid 该注解主要用于字段为一个包含其他对象的集合或map或数组的字段,或该字段直接为一个其他对象的引用,这样在检查当前对象的同时也会检查该字段所引用的对象。
@NotEmpty 验证注解的元素值不为 null 且不为空(字符串长度不为 0、集合大小不为 0)
@Range(min=最小值, max=最大值)验证注解的元素值在最小值和最大值之间
@NotBlank 验证注解的元素值不为空(不为 null、去
除首位空格后长度为 0),不同于@NotEmpty, @NotBlank 只应用于字符串且在比较时会去除字符串的空格
@Length(min=下限, max=上限) 验证注解的元素值长度在 min 和 max 区间内
@Email 验证注解的元素值是 Email,也可以通过正则表达式和 flag 指定自定义的 email 格式
4. 小结
- 永远不要相信用户的输入,我们开发的系统凡是涉及到用户输入的地方,都要进行校验,这里的校验分为前台校验和后台校验,前台校验通常由javascript来完成,后台校验主要由java来负责,这里我们可以通过spring mvc+hibernate validator。