Validation--自定义校验

前言:

今天学到这个,闲着也是闲着,就写一个记录一下,也算是总结

我们的步骤是这样的

1.自定义注解State
2.自定义校验数据的类StateValidation实现ConstrainValidator接口
3.在需要校验的地方使用自定义注解

1.自定义注解

这边以State为例,创建注解

Validation--自定义校验_第1张图片

参考@NotEmpty设计我们的注解

//
// Source code recreated from a .class file by IntelliJ IDEA
// (powered by Fernflower decompiler)
//

package javax.validation.constraints;

import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Repeatable;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import javax.validation.Constraint;
import javax.validation.Payload;

@Documented
@Constraint(
    validatedBy = {}
)
@Target({ElementType.METHOD, ElementType.FIELD, ElementType.ANNOTATION_TYPE, ElementType.CONSTRUCTOR, ElementType.PARAMETER, ElementType.TYPE_USE})
@Retention(RetentionPolicy.RUNTIME)
@Repeatable(NotEmpty.List.class)
public @interface NotEmpty {
    String message() default "{javax.validation.constraints.NotEmpty.message}";

    Class[] groups() default {};

    Class[] payload() default {};

    @Target({ElementType.METHOD, ElementType.FIELD, ElementType.ANNOTATION_TYPE, ElementType.CONSTRUCTOR, ElementType.PARAMETER, ElementType.TYPE_USE})
    @Retention(RetentionPolicy.RUNTIME)
    @Documented
    public @interface List {
        NotEmpty[] value();
    }
}

这边我把比较有用的博客给找出来,有空可以看看

@Documented注解的作用-CSDN博客

java常见的注解之 @Target-CSDN博客

@Retention注解详解-CSDN博客

java中@Repeatable的理解-CSDN博客@Repeatable-CSDN博客

使用中最为关键的

Spring注解之——@Constraint 自定义约束注解-CSDN博客

这边我们不使用@Repeatable与@Retention(使用默认的class作用范围)

package com.yjzx.anno;

import com.yjzx.validation.StateValidation;

import javax.validation.Constraint;
import javax.validation.Payload;
import java.lang.annotation.*;

@Target({ElementType.FIELD})//元注解
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Constraint(
        validatedBy = {StateValidation.class}//指定要识别的类
)
public @interface State {
    //提供校验失败后的提示信息
    String message() default "state参数的值只能是已发布或者草稿 ";
    //指定分组
    Class[] groups() default {};
    //负载,获取State注解附加信息
    Class[] payload() default {};

}

2.自定义校验数据的类实现ConstrainValidator接口

这边使用StateValidation实现,并继承isValid方法

package com.yjzx.validation;

import com.yjzx.anno.State;

import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;

public class StateValidation implements ConstraintValidator {

    /**
     *
     * @param s 将来要校验的数据
     * @param constraintValidatorContext
     * @return  若返回false则不通过,true校验通过
     */
    @Override
    public boolean isValid(String s, ConstraintValidatorContext constraintValidatorContext) {
        //提供校验规则
        if(s==null){
            return false;
        }
        if(s.equals("已发布")||s.equals("草稿")){
            return true;
        }
        return false;
    }
}

3.在需要校验的地方使用自定义注解

像这样,因为我设置的@Target是字段、枚举的常量,可以这么使用,其他请去上面找一下

@Target({ElementType.FIELD})
 @State
    private String state;//发布状态 已发布|草稿

 结果的话,我这边插一个出错的截图吧

 就是这样,如果是对的就正常运行

结束。

你可能感兴趣的:(SpringBoot,java,开发语言)