@Validated 自定义校验注解
面临特殊的校验需要我们可以通过正则表达式来处理,当然我们也可以通过自定义校验注解的方式来实现。
具体步骤
- 需要自定义一个注解
- 创建一个自定义的校验器
- 关联自定义的校验注解和校验器
创建自定义的校验注解 例:实现只能接受指定的数据
@Documented
@Constraint(
validatedBy = {InterValueConstraintValidator.class}
)
@Target({ElementType.METHOD, ElementType.FIELD, ElementType.ANNOTATION_TYPE, ElementType.CONSTRUCTOR, ElementType.PARAMETER, ElementType.TYPE_USE})
@Retention(RetentionPolicy.RUNTIME)
public @interface InterValue {
// 指定默认的提示信息
String message() default "提交的数据不在制指定范围";
//可以注解检验分组
Class<?>[] groups() default {};
Class<? extends Payload>[] payload() default {};
//后台指定的参数
int[] value()default {};
}
创建一个自定义的校验器
package top.nanye.mall.common.validator;
import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;
import java.lang.annotation.Annotation;
import java.lang.reflect.Field;
import java.util.HashSet;
/**
* 自定义校验器
*/
public class InterValueConstraintValidator implements ConstraintValidator<InterValue, Integer> {
private HashSet<Integer> set = new HashSet<>();
/**
* 初始化方法
*
* @param constraintAnnotation
*/
@Override
public void initialize(InterValue constraintAnnotation) {
// 获取接口收到的值
int[] value = constraintAnnotation.value();
for (int i : value) {
set.add(i);
}
}
/**
* 判断检验是否成功的方法
*
* @param integer 后台配置的校验的值
* @param constraintValidatorContext
* @return
*/
@Override
public boolean isValid(Integer integer, ConstraintValidatorContext constraintValidatorContext) {
//符合检验规则返回 TRUE(通过校验) 否则flase(不通过检验)
return set.contains(integer);
}
}
关联自定义的校验注解和校验器
步骤1处 绑定校验器
直接使用
效果