使用Spring注入Hibernate验证框架

 更新时间:2021年12月02日 14:45:20   作者:clypm  
这篇文章主要介绍了使用Spring注入Hibernate验证框架方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

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";
}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

最新评论