通过实现ConstraintValidator完成自定义校验注解

142 篇文章 1 订阅
127 篇文章 2 订阅

首先贴上代码

/**
 * @author hsw
 * @Date 11:28 2018/7/26
 */
@Data
public class LoginVO {
    @NotNull
    @IsMobile
    private String mobile;
 
    @NotNull
    @Length(min = 32)
    private String password;
 
}
/**
 * @author hsw
 * @Date 16:55 2018/7/26
 */
public class IsMobileValidator implements ConstraintValidator<IsMobile,String> {
 
    private boolean require = false;
 
    @Override
    public void initialize(IsMobile constraintAnnotation) {
        require = constraintAnnotation.required();
    }
 
    @Override
    public boolean isValid(String s, ConstraintValidatorContext constraintValidatorContext) {
        if(require){
            return ValidatorUtils.isMobile(s);
        }else {
           if (StringUtils.isEmpty(s)) {
               return true;
           }else {
               return ValidatorUtils.isMobile(s);
           }
        }
    }
}
/**
 * @author hsw
 * @Date 16:54 2018/7/26
 */
@Target(ElementType.FIELD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Constraint(
        validatedBy = {IsMobileValidator.class}
)
public @interface IsMobile {
 
    boolean required() default true;
 
    String message() default "手机号格式不正确";
 
    Class<?>[] groups() default {};
 
    Class<? extends Payload>[] payload() default {};
 
    
}
public class ValidatorUtils {
 
    private static final Pattern mobile_pattern = Pattern.compile("1\\d{10}");
 
    public static boolean isMobile(String src) {
        if (StringUtils.isEmpty(src)) {
            return false;
        }
        Matcher m = mobile_pattern.matcher(src);
        return m.matches();
    }
}
LoginVO类为一个普通的实体类,其中的mobile属性添加了自定义注解。
IsMobile类为自定义的字段注解,未了解过注解的同学请自行百度,在此不做基础介绍。该自定义注解类中用到了四种元注解,最后一个@Constraint指定了校验类,也就是接下来的IsMobileValidator类。值得一提的是除了自定义的message、require属性外,下面的groups和payload也是必须添加的。
ValidatorUtils为一个工具类,简单校验了是否为手机号,没有了解过的可以看我之前的一篇博文:https://blog.csdn.net/qq_38439885/article/details/80230753
IsMobileValidator为自定义注解的校验类。
校验类需要实现ConstraintValidator接口。
接口使用了泛型,需要指定两个参数,第一个自定义注解类,第二个为需要校验的数据类型。
实现接口后要override两个方法,分别为initialize方法和isValid方法。其中initialize为初始化方法,可以在里面做一些初始化操作,isValid方法就是我们最终需要的校验方法了。可以在该方法中实现具体的校验步骤。本示例中进行了简单的手机号校验。

完成这几部分之后,一个简单的自定义校验注解就完成啦,不要忘记在使用的时候加上@Valid注解开启valid校验。

那么如何获取在注解中定义的message信息呢?

在valid校验中,如果校验不通过,会产生BindException异常,捕捉到异常后可以获取到defaultMessage也就是自定义注解中定义的内容,具体实现如下:

    BindException ex = (BindException)e;
    List<ObjectError> errors = ex.getAllErrors();
    ObjectError error = errors.get(0);
    String msg = error.getDefaultMessage();
本文仅供学习记录使用。欢迎交流。
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值