Validation实现自定义校验

目标:创建一个@State注解实现自定义校验,被校验字段只能为String类型的 已发布 和 草稿

  1. 在项目下创建一个包 名字为anno用于存放自定义校验的注解
  2. 创建自定义校验注解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 {};
}

  1. 项目下创建一个包 名字叫validation用于存放自定义校验注解的校验规则
  2. 创建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;
    }
}

  1. 在需要的实体类上使用自定义校验注解
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值