@CONSTRAINT配合自定义注解开发

介绍

通常我们在开发的过程中,需要对前端传入的数据进行校验,尽管这一步已经在前端进行了一次校验,虽然现在已经有了很多校验的注解,@NotNull、@NotBlank、@URL等一系列注解帮助我们进行校验,但是在实际的业务开发过程中,这些可能不足以满足我们的需求,这时候我们就需要自己来定义注解了。

示例DEMO

@Target({TYPE, ANNOTATION_TYPE, FIELD})
@Retention(RetentionPolicy.RUNTIME)
@Constraint(validatedBy = {StringValidator.class})
public @interface NotBlank {

    boolean required() default true;

    String message() default Messages.CK_NOT_BLANK_DEFAULT;

    String value() default "";

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

    Class<? extends Payload>[] payload() default {};
}
public class StringValidator implements ConstraintValidator<NotBlank, String> {
    @Override
    public void initialize(NotBlank constraintAnnotation) {

    }

    @Override
    public boolean isValid(String value, ConstraintValidatorContext context) {
        if (value == null || StringUtils.isBlank(value) || StringUtils.isEmpty(value.trim())) {
            return false;
        }
        return true;
    }
}
/**
 * GetList Group  用于getList方法查询时
 *
 */
public interface GetList {
}

/**
 * Insert Group 用于add方法时
 */
public interface Insert {
}

public interface Update {
}

/**
 * Default Group, 默认分组
 *
 */
public interface Default {
}
@Data
public class BlogVO {

    /**
     * 博客标题
     */
    @NotBlank(groups = {Insert.class, Update.class, Default.class})
    private String title;
}

image

总结

  1. 使用该注解的时候,需要注意自定义规范,即demo中的StringValidator;
  2. 是结合@Validated一起使用的,例如例子中的添加博客方法,使用了Insert.class,因为针对title字段,只有标准了Insert.class, Update.class, Default.class,其中之一才会进行非空校验,而Intert.class在其中,所以需要进行非空校验,主要就是执行StringValidator.isValid()该逻辑,如果返回true,则不为空,返回false,则为空;同时空的提示就是Messages.CK_NOT_BLANK_DEFAULT,这是自定义的提示信息;

参考博客

使用@CONSTRAINT配合自定义注解开发

posted @ 2022-04-20 11:52  卡卡罗特琪琪  阅读(317)  评论(0编辑  收藏  举报