情景:需要对String类型的属性比如description进行验证,验证规则是当description为空时不进行正则校验,description不为空时进行正则校验。上述需求Hibernate Validation没有可用于上述需求的注解,故自定义一个注解并自定义校验规则。
自定义注解进行校验的步骤
- 写一个校验注解,在注解中指定校验器类,校验注解与校验器一般一一对应。
- 写一个校验器类并在校验器类中写校验逻辑,校验器必须实现ConstraintValidator, ?>接口,第一个参数是对应的注解,第二个参数是要校验的属性的类型
代码示例
校验注解
package com.kunlun.validation.annotation;
import java.lang.annotation.documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import javax.validation.Constraint;
import javax.validation.Payload;
import com.kunlun.validation.validator.KlPatternValidator;
@documented
// 指定该注解可以使用的地方
@Target(value= {ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
// 指定实际进行校验的校验器,该校验器是自己写的且必须实现ConstraintValidator接口
@Constraint(validatedBy=KlPatternValidator.class)
public @interface KlPattern {
String message() default "不符合正则!";
Class>[] groups() default {};
Class extends Payload>[] payload() default {};
// 没加default给定默认值,使用注解的时候该属性必须赋值,否则报错
String regex();
// value属性,加上了default "mercy" 使得该属性在使用注解的时候可以不用输入也不会报错
String value() default "mercy";
}
与上面校验注解对应的校验器类
package com.kunlun.validation.validator; import javax.validation.ConstraintValidator; import javax.validation.ConstraintValidatorContext; import com.kunlun.validation.annotation.KlPattern; public class KlPatternValidator implements ConstraintValidator{ private String regex; @Override public void initialize(KlPattern constraintAnnotation) { ConstraintValidator.super.initialize(constraintAnnotation); regex = constraintAnnotation.regex(); } @Override public boolean isValid(String s, ConstraintValidatorContext ctx) { // 当前前端传过来的请求参数是空串,或者没传的时候,不进行后续正则校验 if ("".equals(s) || s == null) { return true; } // 进行正则校验 if(s.matches(regex)) { return true; } return false; } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持考高分网。



