使用Spring注入Hibernate验证框架

Spring配置文件

<!-- Enables the Spring MVC @Controller programming model -->
<mvc:annotation-driven validator="validator" />

<!-- 配置数据校验 -->
<bean id="messageSource"
class="org.springframework.context.support.ReloadableResourceBundleMessageSource">  
      <property name="basename" value="classpath:messages"/>
      <property name="fileEncodings" value="utf-8"/>
      <property name="cacheSeconds" value="10"/>
</bean>
<bean id="validator"
class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean">  
      <property name="providerClass"
 value="org.hibernate.validator.HibernateValidator"/>
<property name="validationMessageSource" ref="messageSource"/>
</bean>

Hibernate内置的验证约束注解如下表所示

(摘自hibernate validator reference):

验证注解

验证的数据类型

说明

@AssertFalse

Boolean,boolean

验证注解的元素值是false

@AssertTrue

Boolean,boolean

验证注解的元素值是true

@NotNull

任意类型

验证注解的元素值不是null

@Null

任意类型

验证注解的元素值是null

@Min(value=值)

BigDecimal,BigInteger, byte,

short, int, long,等任何Number或CharSequence(存储的是数字)子类型

验证注解的元素值大于等于@Min指定的value值

@Max(value=值)

和@Min要求一样

验证注解的元素值小于等于@Max指定的value值

@DecimalMin(value=值)

和@Min要求一样

验证注解的元素值大于等于@ DecimalMin指定的value值

@DecimalMax(value=值)

和@Min要求一样

验证注解的元素值小于等于@ DecimalMax指定的value值

@Digits(integer=整数位数, fraction=小数位数)

和@Min要求一样

验证注解的元素值的整数位数和小数位数上限

@Size(min=下限, max=上限)

字符串、Collection、Map、数组等

验证注解的元素值的在min和max(包含)指定区间之内,如字符长度、集合大小

@Past

java.util.Date,

java.util.Calendar;

Joda Time类库的日期类型

验证注解的元素值(日期类型)比当前时间早

@Future

与@Past要求一样

验证注解的元素值(日期类型)比当前时间晚

@NotBlank

CharSequence子类型

验证注解的元素值不为空(不为null、去除首位空格后长度为0),不同于@NotEmpty,@NotBlank只应用于字符串且在比较时会去除字符串的首位空格

@Length(min=下限, max=上限)

CharSequence子类型

验证注解的元素值长度在min和max区间内

@NotEmpty

CharSequence子类型、Collection、Map、数组

验证注解的元素值不为null且不为空(字符串长度不为0、集合大小不为0)

@Range(min=最小值, max=最大值)

BigDecimal,BigInteger,CharSequence, byte, short, int, long等原子类型和包装类型

验证注解的元素值在最小值和最大值之间

@Email(regexp=正则表达式,

flag=标志的模式)

CharSequence子类型(如String)

验证注解的元素值是Email,也可以通过regexp和flag指定自定义的email格式

@Pattern(regexp=正则表达式,

flag=标志的模式)

String,任何CharSequence的子类型

验证注解的元素值与指定的正则表达式匹配

@Valid

任何非原子类型

指定递归验证关联的对象;

如用户对象中有个地址对象属性,如果想在验证用户对象时一起验证地址对象的话,在地址对象上加@Valid注解即可级联验证

 

springmvc使用Hibernate的校验框架validation

一、Hibernate中的validator需要的jar包

  • hibernate-validator-4.3.1.Final.jar
  • jboss-logging-3.1.0.GA.jar
  • validation-api-1.1.0.Final.jar

二、配置校验器

<!-- 校验器 -->
  <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.ReloadableResourceBundleMessageSource">
      <!-- 资源文件名-->
      <property name="basenames">   
          <list>    
          <value>classpath:CustomValidationMessages</value>
          </list>   
      </property>
      <!-- 资源文件编码格式 -->
      <property name="fileEncodings" value="utf-8" />
      <!-- 对资源文件内容缓存时间,单位秒 -->
      <property name="cacheSeconds" value="120" />
  </bean>

三、校验器注册到处理器适配器中

<mvc:annotation-driven validator="validator"></mvc:annotation-driven>     

四、在pojo中添加校验规则

package acm.user.po; 
import javax.validation.constraints.NotNull;
import javax.validation.constraints.Size;

public class User {
  private Integer id; 
  //校验名字1到30个字符中间
  //message是提示校验出错信息
  @Size(min=1, max=30, message="{user.name.length.error}")
  private String name; 
  //非空校验
  @NotNull(message="{user.num.noNull}")
  private String num; 
  private String sex; 
  private String tel;
          .
          .
          .
          .
  public Integer getId() {
      return id;
  } 
  public void setId(Integer id) {
      this.id = id;
  } 
}

配置文件中的代码

user.name.length.error=请输入1到30个字符的名字
user.num.noNull=请输入商品的生产日期

五、controller测试

@RequestMapping(value = "updateUser")
public String updateUser(@Validated User user, BindingResult bindingResult){
  List<ObjectError> allErrors = bindingResult.getAllErrors();
  //获得错误信息
  for(ObjectError e : allErrors){
      //输出错误信息
      System.out.println(e.getDefaultMessage());   
  }
  try{
      int count = userService.updateUser(user);
  } catch(Exception e){
      e.printStackTrace();
  }
  return "message";
} 

分组校验:

定义多个校验分组,分组中定义有些规则

每个controller方法中定义不同的校验分组

定义一个接口,里面可以不写东西,用来装一个分组

在pojo中写出每一个被校验的字段属于哪一个分组

//校验名字1到30个字符中间
//message是提示校验出错信息
//标识此校验属于哪个分组,group也可属于多个分组
@Size(min=1, max=30, message="{user.name.length.error}", groups={Validation1.class})
private String name;

在controller里使用分组校验

@Validated中的参数指向那个检验分组
@RequestMapping(value = "updateUser")
public String updateUser(@Validated(value={Validation1.class}) User user, BindingResult bindingResult){
  if(bindingResult.hasErrors()){
      List<ObjectError> allErrors = bindingResult.getAllErrors();
      //获得错误信
     for(ObjectError e : allErrors){
          //输出错误信息
          System.out.println(e.getDefaultMessage());
      }
  }
  try{
      int count = userService.updateUser(user);
  } catch(Exception e){
      e.printStackTrace();
  }
  return "message";
}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程宝库

 方法参数public String listFireEvent(@Valid FireSearch fireSearch, HttpServletRequest req ...