服务器端校验(安全性较高)
controller层:校验请求参数的合法性.
service层:校验关键业务数据(service接口中的参数).
dao层:无校验.
springmvc校验使用的是hibernate的校验框架validation(和hibernate无关系)。
配置校验器:
springmvc.xml
<mvc:annotation-driven conversion-service="conversionService" validator="validator">
</mvc:annotation-driven>
<!-- 校验器 -->
<bean id="validator"
class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean">
<!-- 指定校验器,可以是别的校验器 -->
<property name="providerClass" value="org.hibernate.validator.HibernateValidator"></property>
<!-- 指定校验资源文件,默认为classspath下的validationMessage.properties -->
<property name="validationMessageSource" ref="messageResource" />
</bean>
<bean id="messageResource" class="org.springframework.context.support.ReloadableResourceBundleMessageSource" >
<!-- 资源文件名 -->
<property name="basenames">
<list>
<value>classpath:productValidationMessage</value>
</list>
</property>
<!-- 编码 -->
<property name="fileEncodings" value="utf-8" />
<!-- 对资源文件内容缓存时间 -->
<property name="cacheSeconds" value="120" />
</bean>
在properties文件中设置校验信息
#添加错误校验信息
product.proName.length.error=请输入6-30个字符
product.price.isNull=价钱不能为空
在pojo中添加校验规则
@Size(min=6,max=30,message="{product.proName.length.error)
private String proName; //商品名
@NotNull(message="{product.price.isNull)
private BigDecimal price; //商品价格
捕获校验信息
//在需要验证的pojo前添加@Validated, 在之后添加BindingResult bindingResult接收校验出错信息(顺序固定)
@RequestMapping(value="/findProList")
public String findProList(Model model,@Validated Product product,BindingResult bindingResult) throws Exception {
if(bindingResult.hasErrors() )
{
model.addAttribute("allErrors", bindingResult.getAllErrors());
//在页面中显示
return "index";
}
}
在页面中显示
使用c标签循环遍历,错误信息属性为defaultMessage
校验分组
分组与pojo整体校验冲突,分组后规则的必须通过选择分组才会校验
在pojo中设置规则时添加分组
@Size(min=6,max=30,message="{product.proName.length.error}", groups={Group1Valida.class,Group2Valida.class})
private String proName; //商品名
@NotNull(message="{product.price.isNull}",groups={Group1Valida.class})
private BigDecimal price; //商品价格
选择分组
//修改商品信息
@RequestMapping(value="/alterPro")
public String alterPro(Model model,@Validated(value={Group1Valida.class}) ProductCustom product,
BindingResult bindingResult) throws Exception
选择分组Group1Valida会校验商品名与价格,选择Group2Valida只会校验商品名