1.JSR 303 校验框架介绍
@NotNull 注解元素必须是非空
@Null 注解元素必须是空
@Digits 验证数字构成是否合法
@Future 验证是否在当前系统时间之后
@Past 验证是否在当前系统时间之前
@Max 验证值是否小于等于最大指定整数值
@Min 验证值是否大于等于最小指定整数值
@Pattern 验证字符串是否匹配指定的正则表达式
@Size 验证元素大小是否在指定范围内
@DecimalMax 验证值是否小于等于最大指定小数值
@DecimalMin 验证值是否大于等于最小指定小数值
@AssertTrue 被注释的元素必须为true
@AssertFalse 被注释的元素必须为false
2.Hibernate Validator 扩展
@Email 被注释的元素必须是电子邮箱地址
@Length 被注释的字符串的大小必须在指定的范围内
@NotEmpty 被注释的字符串的必须非空
@Range 被注释的元素必须在合适的范围内
3.配置和使用 SpringMVC 校验框架
springmvc.xml中进行配置:
javabean中对属性@
@NotEmpty(message="{NotEmpty.user.userName}")
private String userName ;
@Pattern(regexp="[0-9a-zA-Z]{6,30}", message="{Pattern.user.password}")
private String password ;
@Length(min=2, max=100, message="{Length.user.realName}")
private String realName ;
@Email(message="{Email.user.email}")
private String email ;
@NotNull(message = "{NotNull.user.age}")
@Between(min = 18, max = 45)
private Integer age ;
Controller配置:方法参数处(@Valid User user,BindingResult result)
@RequestMapping(value = "/doRegister", method = RequestMethod.POST)
public String doLogin(@Valid User user, BindingResult result, ModelMap map){
// 如果入参有问题,返回注册页面
if (result.hasErrors()) {
List errorList = result.getFieldErrors();
for(FieldError error : errorList){
System.out.println(error.getField() + "*" + error.getDefaultMessage());
//ModelMap很好用,压进去,待EL取
map.put("ERR_" + error.getField(), error.getDefaultMessage());
}
return "/WEB-INF/jsp/register.jsp";
}
// 这里省略注册代码
return "/WEB-INF/jsp/registersuccess.jsp";
}
校验结果放在BindingResult或Errors对象中
Errors接口提供获取错误信息的方法,如getErrorCount()获取错误的数量, getFieldErrors(String field)得到成员属性的校验错误列表
BindingResult接口扩展了Errors接口,以便可以使用Spring的org.springframeword.validation.Validator对数据进行校验,同时获取数据绑定结果对象的信息
国际化信息:i18n文件夹,新建messages.properties和messages_zh_CN.properties
/WEB-INF/springmvc.xml中配置
<mvc:annotation-driven validator="validator" />
<bean id="validator" class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean">
<property name="providerClass" value="org.hibernate.validator.HibernateValidator" />
<property name="validationMessageSource" ref="messageSource" />
bean>
<bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource"
p:basename="i18n/messages" />
自定义校验规则:定义注解类,并使用Constraint注解标注,属性validatedBy指定校验实现类
定义实现类,需要集成ConstraintValidator接口,isValid方法负责校验