- controller:校验页面请求参数的合法性,在服务端控制controller校验,不区分客户端类型
- service:主要校验关键业务参数,仅限于service接口中使用的参数
- dao:一般不校验
springmvc使用hibernate校验框架validation(和hibernate没有关系)
校验思路
- 页面提交的请求参数,请求到controller方法中,使用validation进行校验,如果校验出错,将错误信息展示到页面
准备环境
<dependency>
<groupId>org.hibernate.validator</groupId>
<artifactId>hibernate-validator</artifactId>
<version>6.0.10.Final</version>
</dependency>
spingmvc.xml
<mvc:annotation-driven conversion-service="conversionService" validator="validation"/>
<!--校验器-->
<bean id="validator" class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean">
<!--校验器-->
<property name="providerClass" value="org.hibernate.validator.HibernateValidator"/>
<!--指定校验使用的资源文件,如不指定默认使用ValidationMessages.properties-->
<property name="validationMessageSource" ref="messageSource"/>
</bean>
<!--校验错误信息配置文件-->
<bean id="messageSource" class="org.springframework.context.support.ReloadableResourceBundleMessageSource">
<!--资源文件名-->
<property name="basenames">
<list>
<value>classpath:CustomValidationMessages.properties</value>
</list>
</property>
<!--资源文件编码格式-->
<property name="fileEncoding" value="utf-8"/>
<!--对资源文件内容缓存数据,单位秒-->
<property name="cacheSeconds" value="120"/>
</bean>
CustomValidationMessages.properties
#添加校验错误提交信息
items.name.length.error=请输入1~30字符
items.createtime.isNull=请输入商品生产时间
pojo添加校验信息
public class Items{
//校验1~30字符之间
//message是提示校验出错显示的信息
@Size(min=1,max=30,message="{items.name.length.error}")
private String name;
//非空校验
@NotNulll(message="{items.createtime.isNull}")
private Date createtime;
}
校验
//需要在校验的pojo前添加@Validated,并使用BindingResult接受校验信息,必须配对出现,一前一后固定顺序
@RequestMapping("/xxx")
public String editItems(Model model,@Validated Items items,BindingResult bindingResult)throws Exception{
//获取校验信息
if(bindingResult.hasErrors()){
//输出错误信息
List<ObjectError> allErrors = bindingResult.getAllErrors();
model.addAttribute("allErrors",allErrors);
}
return null;
}
相同的pojo不同的controller不同的校验规则
定义多个校验分组
public interface ValidGroup1{
//接口中不需要定义任何方法,仅是对不同的校验规则进行分组
}
public interface ValidGroup2{
//接口中不需要定义任何方法,仅是对不同的校验规则进行分组
}
public interface ValidGroup3{
//接口中不需要定义任何方法,仅是对不同的校验规则进行分组
}
校验规则中添加分组
public class Items{
//校验1~30字符之间
//message是提示校验出错显示的信息
//groups:此校验规则分组,可以指定多个
@Size(min=1,max=30,message="{items.name.length.error}",groups={ValidGroup1.class})
private String name;
//非空校验
@NotNulll(message="{items.createtime.isNull}")
private Date createtime;
}
Controller中指定分组校验
//@Validated(value={ValidGroup1.class})指定使用分组校验
@RequestMapping("/xxx")
public String editItems(Model model,@Validated(value={ValidGroup1.class}) Items items,BindingResult bindingResult)throws Exception{
}