欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

springboot自定义注解校验规则

程序员文章站 2024-03-14 15:04:34
...

一、自定义嵌套参数的校验注解规则

1. 接受前台参数

    //AlyUrgentOutStoreApplyAddDto 为嵌套参数类
    public Result add(@Valid @RequestBody AlyUrgentOutStoreApplyAddDto alyUrgentOutStoreApplyAddDto, HttpServletRequest request) {
        alyUrgentOutService.insertUrgentOutStoreApply(alyUrgentOutStoreApplyAddDto, request);
        return ResultGenerator.genSuccessResult();
    }

2. 接收参数的实体类

import cn.com.magnequench.alloy.web.paramscheck.UrgentOutStoreAnno;

import java.util.Date;
import java.util.List;

/**
 * @Desc TODO   @UrgentOutStoreAnno注解为自定义注解
 **/
@UrgentOutStoreAnno
public class AlyUrgentOutStoreApplyAddDto {

    private String applyMemo;
    private Date claimTime;
    private List<AlyUrgentOutStoreUseDataDto> selected;

    public String getApplyMemo() {
        return applyMemo;
    }

    public void setApplyMemo(String applyMemo) {
        this.applyMemo = applyMemo;
    }

    public Date getClaimTime() {
        return claimTime;
    }

    public void setClaimTime(Date claimTime) {
        this.claimTime = claimTime;
    }

    public List<AlyUrgentOutStoreUseDataDto> getSelected() {
        return selected;
    }

    public void setSelected(List<AlyUrgentOutStoreUseDataDto> selected) {
        this.selected = selected;
    }
}

3. 自定义注解

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

@Documented
@Target({ ElementType.METHOD, ElementType.FIELD, ElementType.TYPE })
@Retention(RetentionPolicy.RUNTIME)
@Constraint(validatedBy = { UrgentOutStoreValidator.class})
/**
  * @Desc //TODO  自定义校验注解,UrgentOutStoreValidator为自定义校验规则的类
  **/
public @interface UrgentOutStoreAnno {
    String message() default "msg";// 校验的失败的时候返回的信息,可以指定默认值

    Class<?>[] groups() default { };

    Class<? extends Payload>[] payload() default {};
}

4. 自定义校验注解的规则

import cn.com.magnequench.alloy.dto.AlyUrgentOutStoreApplyAddDto;
import cn.com.magnequench.alloy.dto.AlyUrgentOutStoreUseDataDto;
import common.core.utils.StringUtils;

import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;
import java.util.List;

/**
 * @Desc TODO
 **/
public class UrgentOutStoreValidator implements ConstraintValidator<UrgentOutStoreAnno,AlyUrgentOutStoreApplyAddDto> {

    @Override
    public void initialize(UrgentOutStoreAnno constraintAnnotation) {
    }

    @Override
    public boolean isValid(AlyUrgentOutStoreApplyAddDto alyUrgentOutStoreApplyAddDto, ConstraintValidatorContext context) {
        // 处理校验逻辑 

        return false;
    }
}

二、元注解

元注解的作用就是负责注解其他注解

1. @Documented

Documented 可以作用于类上及类方法上,表明这个注释是由 javadoc记录的,在默认情况下也有类似的记录工具。 如果一个类型声明被注释了文档化,它的注释成为公共API的一部分

2. @Target

是用来修饰注解的元注解,它有一个属性ElementType是枚举类型

  • ElementType.TYPE:类、接口(包括注释类型)或枚举声明
  • ElementType.FIELD:字段声明(包括枚举常量)
  • ElementType.METHOD:方法声明
  • ElementType.PARAMETER:形式参数声明
  • ElementType.CONSTRUCTOR:构造函数声明
  • ElementType.LOCAL_VARIABLE:局部变量声明
  • ElementType.ANNOTATION_TYPE:批注类型声明
  • ElementType.PACKAGE:包声明
  • ElementType.TYPE_PARAMETER:类型参数声明
  • ElementType.TYPE_USE:类型的使用
  • ElementType.MODULE:模块声明

3. @Retention

是用来修饰注解的元注解,它有一个属性RetentionPolicy是枚举类型

  • RetentionPolicy.SOURCE:注释将被编译器丢弃
  • RetentionPolicy.CLASS:注释将由编译器记录在类文件中,但不需要在运行时由VM保留。这是默认行为
  • RetentionPolicy.RUNTIME:注释将由编译器记录在类文件中,并在运行时由VM保留,因此可以反射地读取注释

4. @Constraint(validatedBy = { })

validatedBy属性指定了需要进行校验的策略类集合,这是一个数组
{} 数组中的类要 implements ConstraintValidator<UrgentOutStoreAnno,AlyUrgentOutStoreApplyAddDto>接口,ConstraintValidator第一个类型是自定义校验注解,第二个是使用自定义注解接受参数的实体类

转载于:https://www.jianshu.com/p/6fb398cf48c3