jsr-303 参数校验—自定义校验注解

Posted niceyoo

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了jsr-303 参数校验—自定义校验注解相关的知识,希望对你有一定的参考价值。

1、为什么要自定义?

通过上篇学习,了解到很多常用注解了,但是呢,总是有那么些需求....
 

2、案例分析(手机号格式)

2.1、需要验证的实体 Bean

public class LoginVo {
    
    @NotNull
    @IsMobile //自定义的注解
    private String mobile;
    
    @NotNull
    @Length(min=32)
    private String password;
    
    //省略 get set 方法
}
 

2.2、自定义 IsMobile  注解类

import static java.lang.annotation.ElementType.ANNOTATION_TYPE;
import static java.lang.annotation.ElementType.CONSTRUCTOR;
import static java.lang.annotation.ElementType.FIELD;
import static java.lang.annotation.ElementType.METHOD;
import static java.lang.annotation.ElementType.PARAMETER;
import static java.lang.annotation.RetentionPolicy.RUNTIME;
import java.lang.annotation.Documented;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;
import javax.validation.Constraint;
import javax.validation.Payload;
 
@Target({ METHOD, FIELD, ANNOTATION_TYPE, CONSTRUCTOR, PARAMETER })
@Retention(RUNTIME)
@Documented
@Constraint(validatedBy = {IsMobileValidator.class })
public @interface  IsMobile {
    
  //允许为空的属性
    boolean required() default true;
 
    //如果校验不通过返回的提示信息
    String message() default "手机号码格式错误";
 
    Class<?>[] groups() default { };
 
    Class<? extends Payload>[] payload() default { };
}

 

2.3、校验器

 
import  javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;
import org.apache.commons.lang3.StringUtils;
import com.imooc.miaosha.util.ValidatorUtil;
 
//IsMobile:自定义的注解
//String:注解参数类型
public class IsMobileValidator implements ConstraintValidator<IsMobile, String> {
 
  //默认值_false,用于接收注解上自定义的 required
    private boolean required = false;
    
  //1、初始化方法:通过该方法我们可以拿到我们的注解
    public void initialize(IsMobile constraintAnnotation) {
 
        //constraintAnnotation.required() 接收我们自定义的属性,是否为空
        required = constraintAnnotation.required();
    }
 
  //2、逻辑处理
    public boolean isValid(String value, ConstraintValidatorContext context) {
 
        //2.1、如果允许为空的话,直接返回结果
        if(required) {
            return ValidatorUtil.isMobile(value);
        }else {
        //2.2、不允许为空
            //2.2.1、验证是否为空
            if(StringUtils.isEmpty(value)) {
                return true;
            }else {
                return ValidatorUtil.isMobile(value);
            }
        }
    }
 
}

 

3、总结

 
自定义注解需要去手动实现两个文件:自定义注解类 + 注解校验器类
 
自定义注解类:message() + groups() + payload() 必须;
 
注解校验器类:继承 ConstraintValidator 类<注解类,注解参数类型> + 两个方法(initialize:初始化操作、isValid:逻辑处理)

 

以上是关于jsr-303 参数校验—自定义校验注解的主要内容,如果未能解决你的问题,请参考以下文章

商城项目10_JSR303常用注解在项目中如何使用统一处理异常分组校验功能自定义校验注解

SpringBoot中集成参数校验

SpringBoot中集成参数校验

第185天学习打卡(项目 谷粒商城27 JSR303自定义校验注解 SPU SKU 属性分组效果前端组件抽取 父子组件交互)

jsr-303 参数校验-学习(转)

SpringBoot后端进行数据校验——JSR303的使用