自定义校验注解:枚举、列举模式

1、想使用枚举作为参数校验对象,减少手工代码量。
2、有些参数是固定的,列举校验,减少…

一、枚举模式

1、一般枚举

注释

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.FIELD, ElementType.PARAMETER})
@Constraint(validatedBy = EnumValidator.class)
public @interface EnumValid {

    Class<?> value() ;

    String message() default "入参值不在正确枚举中";

    /**
     * 默认反射调用的方法
     * @return 返回方法参数
     */
    String method() default "getName";

    Class<?>[] groups() default {};

    Class<? extends Payload>[] payload() default {};

}

校验器

@Slf4j
public class EnumValidator implements ConstraintValidator<EnumValid, String> {

    /**
     * 枚举代码
     */
    private final Set<String> codeList = new HashSet<>();

    @Override
    public void initialize(EnumValid enumValid) {
        Class<?> clazz = enumValid.value();
        Object[] objects = clazz.getEnumConstants();
        try {
            // 反射获取对应方法
            Method method = clazz.getMethod(enumValid.method());
            Object value;
            for (Object obj : objects) {
                // 调用 获取校验值
                value = method.invoke(obj);
                codeList.add((String) value);
            }
        } catch (Exception e) {
            log.error("处理枚举校验异常: ", e);
        }
    }

    @Override
    public boolean isValid(String value, ConstraintValidatorContext constraintValidatorContext) {
        return null == value || codeList.contains(value);
    }

}

默认使用
在这里插入图片描述
非默认使用

使用getAlg作为参数初始化获取函数

在这里插入图片描述
枚举对象示例:
在这里插入图片描述

二、列举模式

1、字符列举

注释

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.FIELD, ElementType.PARAMETER})
@Constraint(validatedBy = StrValidator.class)
public @interface StrValid {

    String[] value() default {};

    String message() default "str val is not found";

    Class<?>[] groups() default {};

    Class<? extends Payload>[] payload() default {};
}

校验器

public class StrValidator implements ConstraintValidator<StrValid, String> {
    private Set<String> limitValues;

    @Override
    public void initialize(StrValid flagValidator) {
        limitValues = Arrays.stream(flagValidator.value()).collect(Collectors.toSet());
    }

    @Override
    public boolean isValid(String value, ConstraintValidatorContext constraintValidatorContext) {
        if (StringUtils.isBlank(value)) {
            //当状态为空时使用默认值
            return true;
        }
        return limitValues.contains(value);
    }
}

用法
在这里插入图片描述

2、整型列举

注释

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.FIELD, ElementType.PARAMETER})
@Constraint(validatedBy = IntValidator.class)
public @interface IntValid {

    int [] value();

    String message() default "int val error";

    Class<?>[] groups() default {};

    Class<? extends Payload>[] payload() default {};
}

校验器

@Slf4j
public class IntValidator implements ConstraintValidator<IntValid, Integer> {

    /**
     * 限制内容
     */
    private int[] limitValues;

    @Override
    public void initialize(IntValid flagValidator) {
        limitValues = flagValidator.value();
    }

    @Override
    public boolean isValid(Integer value, ConstraintValidatorContext constraintValidatorContext) {
        if (null == value) {
            //当状态为空时使用默认值
            return true;
        }
        for (int limitValue : limitValues) {
            if (limitValue == value) {
                return true;
            }
        }
        return false;
    }

}

用法
在这里插入图片描述

最后:
以上校验器不校验空值,不为空需要添加@NotNull注释

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

*crzep

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值