springboot自定义注解校验规则

2019-03-30  本文已影响0人  _fatef

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

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是枚举类型

3. @Retention

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

4. @Constraint(validatedBy = { })

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

上一篇 下一篇

猜你喜欢

热点阅读