您的位置:首页 > 编程语言 > Java开发

三.SpringMVC 数据校验

2017-04-23 23:56 351 查看
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<FieldError> 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" />
<!-- 如果不加默认到 使用classpath下的 ValidationMessages.properties -->
<property name="validationMessageSource" ref="messageSource" />
</bean>

<bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource"
p:basename="i18n/messages" />


自定义校验规则:定义注解类,并使用Constraint注解标注,属性validatedBy指定校验实现类



定义实现类,需要集成ConstraintValidator接口,isValid方法负责校验

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  springmvc validator