Hibernate-Validation

 

一.依赖架包:         

  validation-api-1.0.0.GA.jar

           hibernate-validator-4.3.1.final-1.0.0.jar

          

二.校验工具类

public class ValidationUtils {

    private static Validator validator = Validation.buildDefaultValidatorFactory().getValidator();

    public static  ValidationResult validateEntity(T obj) {

        ValidationResult result = new ValidationResult();

        Set> set = validator.validate(obj, Default.class);

        if (CollectionUtils.isNotEmpty(set)) {

            result.setHasErrors(true);

            Map errorMsg = new HashMap < String, String>();

            for (ConstraintViolation cv : set) {

                errorMsg.put(cv.getPropertyPath().toString(), cv.getMessage());

            }

            result.setErrorMsg(errorMsg);
        }
        return result;
    }

    public static  ValidationResult validateProperty(T obj, String propertyName) {
        ValidationResult result = new ValidationResult();
        Set> set = validator.validateProperty(obj, propertyName, Default.class);
        if (CollectionUtils.isNotEmpty(set)) {
            result.setHasErrors(true);
            Map errorMsg = new HashMap< String, String>();
            for (ConstraintViolation cv : set) {
                errorMsg.put(propertyName, cv.getMessage());
            }
            result.setErrorMsg(errorMsg);
        }
        return result;
    }

}

三、校验返回对象

package com.framework.loippi.utils.vali;

import java.util.Map;

public class ValidationResult {
    //校验结果是否有错

    private boolean hasErrors;

    //校验错误信息

    private Map errorMsg;

    public boolean getHasErrors() {

        return hasErrors;

    }

    public void setHasErrors(boolean hasErrors) {

        this.hasErrors = hasErrors;

    }

    public Map getErrorMsg() {

        return errorMsg;

    }

    public void setErrorMsg(Map errorMsg) {

        this.errorMsg = errorMsg;

    }

}

四.实体类

public class SimpleEntity {
               @NotBlank(message="名字不能为空或者空串")
               @Length(min=2, max=10, message="名字必须由2~10个字组成")
               private String name;
               @Past(message="时间不能晚于当前时间")
               private Date date;
               @Email(message="邮箱格式不正确")
               private String email;
               @Pattern(regexp="(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z]{5,10}",message="密码必须是5~10位数字和字母的组合")
               private String password;
               @AssertTrue(message="字段必须为真")
               private boolean valid;
               //get set方法省略,自己添加
}


五.校验

public void validateSimpleEntity() {
               SimpleEntity se = new SimpleEntity();
               se.setDate(new Date());
               se.setEmail("123");
               se.setName("123");
               se.setPassword("123");
               se.setValid(false);
ValidationResult result = ValidationUtils.validateEntity(se);
               System.out.println("--------------------------");
               System.out.println(result);
               Assert.assertTrue(result.isHasErrors());
  }


返回结果:

ValidationResult [hasErrors=true, errorMsg={name=名字不能为空或者空串}]
ValidationResult [hasErrors=false, errorMsg=null]


六.自定义注解

       若hibernate提供注解不够使用可自定义

@Target( { METHOD, FIELD, ANNOTATION_TYPE })
@Retention(RUNTIME)
@Constraint(validatedBy = PasswordValidator.class)
@Documented
public @interface Password {
    String message() default"{密码必须是5~10位数字和字母组合}";
    Class[] groups() default {};
    Class[] payload() default {};
}


七、密码校验类

/**
 * 自定义密码校验类
 */
 

public class PasswordValidator implements ConstraintValidator{
               //5~10位的数字与字母组合
               privatestatic Pattern pattern = Pattern.compile("(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z]{5,10}");
               public void initialize(Password constraintAnnotation){
                               //do nothing
               }
               public boolean isValid(String value, ConstraintValidatorContext context){
                               if( value==null ){
                                              returnfalse;
                               }
                               Matcher m = pattern.matcher(value);
                               return m.matches();
               }              
}
Constraint 详细信息
@Null 被注释的元素必须为 null
@NotNull 被注释的元素必须不为 null
@AssertTrue 被注释的元素必须为 true
@AssertFalse 被注释的元素必须为 false
@Min(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
@Max(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
@DecimalMin(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
@DecimalMax(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
@Size(max, min) 被注释的元素的大小必须在指定的范围内
@Digits (integer, fraction) 被注释的元素必须是一个数字,其值必须在可接受的范围内
@Past 被注释的元素必须是一个过去的日期
@Future 被注释的元素必须是一个将来的日期
@Pattern(value) 被注释的元素必须符合指定的正则表达式

标准实现者如hibernate-validater提供的约束如下:

Constraint 详细信息
@Email 被注释的元素必须是电子邮箱地址
@Length 被注释的字符串的大小必须在指定的范围内
@NotEmpty 被注释的字符串的必须非空
@Range 被注释的元素必须在合适的范围内

作者:jiangdaquan 
来源:CSDN 
原文:https://blog.csdn.net/jiangdaquan/article/details/80985894 

你可能感兴趣的:(java,编程)