目标:创建一个@State注解实现自定义校验,被校验字段只能为String类型的 已发布 和 草稿
- 在项目下创建一个包 名字为anno用于存放自定义校验的注解
- 创建自定义校验注解State
package org.example.anno;
import jakarta.validation.Constraint;
import jakarta.validation.Payload;
import org.example.validation.StateValidation;
import java.lang.annotation.*;
@Documented//元注解 标识注解可以抽取到帮助文档里面的
@Target(ElementType.FIELD)//元注解 注解使用位置
@Retention(RetentionPolicy.RUNTIME)//元注解 标识注解保留阶段
@Constraint(
validatedBy = {StateValidation.class}
)// 标注谁给注解提供校验规则
public @interface State {
//提供校验失败后的提示信息
String message() default "state参数的值只能为已发布或者草稿";
//指定分组
Class<?>[] groups() default {};
//负载 获取到State注解的附加信息
Class<? extends Payload>[] payload() default {};
}
- 项目下创建一个包 名字叫validation用于存放自定义校验注解的校验规则
- 创建State的校验规则实现类StateValidation
package org.example.validation;
import jakarta.validation.ConstraintValidator;
import jakarta.validation.ConstraintValidatorContext;
import org.example.anno.State;
public class StateValidation implements ConstraintValidator<State, String> {
/**
*
* @param value 将来要校验的数据
* @param context
* @return
*/
@Override
public boolean isValid(String value, ConstraintValidatorContext context) {
//提供State校验规则
if (value==null){
return false;
}
if (value.equals("已发布")||value.equals("草稿")){
return true;
}
return false;
}
}
- 在需要的实体类上使用自定义校验注解