Spring Boot 中自定义注解实现可选 int 值的校验

正文:

在实际的应用开发中,我们经常需要对接口的输入进行校验,以确保数据的合法性。在Spring Boot项目中,通过使用Hibernate Validator等校验框架,可以轻松地实现各种校验需求。本文将介绍如何自定义一个注解@InIntValues,并通过对应的校验器InIntValuesValidator来实现对输入是否为指定可选int值的校验。

1. 创建自定义可选int值校验注解

首先,我们创建一个自定义注解@InIntValues,用于标记需要进行可选int值校验的字段或参数。以下是注解的定义:

java 复制代码
import javax.validation.Constraint;
import javax.validation.Payload;
import java.lang.annotation.*;

/**
 * 可选int值范围校验注解
 */
@Documented
@Constraint(validatedBy = InIntValuesValidator.class)
@Target({ElementType.FIELD, ElementType.PARAMETER})
@Retention(RetentionPolicy.RUNTIME)
public @interface InIntValues {
    // 默认错误提示信息
    String message() default "必须是指定的int值之一";

    // 可选的int值数组
    int[] values();

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

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

2. 创建可选int值校验器

接下来,我们需要实现可选int值校验的逻辑。为此,创建一个InIntValuesValidator类,实现ConstraintValidator<InIntValues, Integer>接口:

java 复制代码
import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;
import java.util.Arrays;

/**
 * 可选int值范围校验器
 */
public class InIntValuesValidator implements ConstraintValidator<InIntValues, Integer> {

    private int[] allowedValues;

    @Override
    public void initialize(InIntValues constraintAnnotation) {
        this.allowedValues = constraintAnnotation.values();
    }

    /**
     * 校验方法
     * @param value 待校验的整数
     * @param context 校验上下文
     * @return 校验结果,true表示通过,false表示不通过
     */
    @Override
    public boolean isValid(Integer value, ConstraintValidatorContext context) {
        // 如果值为null,由 @NotNull 校验
        if (value == null) {
            return true;
        }
        // 判断值是否在可选的int值数组中
        return Arrays.stream(allowedValues).anyMatch(val -> val == value);
    }
}

在这个校验器中,我们使用@InIntValues注解的values()属性来指定可选的int值数组。在isValid方法中,我们使用Java 8的Stream API来判断被验证的值是否在这个可选的int值数组中。

3. 在实体类或DTO中应用注解

现在,你可以在需要进行可选int值校验的字段上应用@InIntValues注解:

java 复制代码
public class YourRequestDTO {
    
    @NotBlank(message = "姓名不能为空")
    @Chinese
    private String name;

    @InIntValues(values = {1, 2, 3}, message = "必须是指定的int值之一")
    private Integer selectedValue;

    // 其他字段...
}

在这个例子中,selectedValue字段通过@InIntValues注解进行了可选int值校验。当请求中的selectedValue字段不是指定的可选int值之一时,将触发校验错误,并返回指定的错误提示信息。

通过这样的自定义注解和校验器,你可以在Spring Boot项目中轻松实现对字段值是否为指定可选int值的校验,提高系统的数据质量和安全性。

相关推荐
NMIXX爻11 分钟前
线程控制 下
java·开发语言·jvm
时艰.33 分钟前
JVM 垃圾收集器(G1&ZGC)
java·jvm·算法
短剑重铸之日1 小时前
《SpringCloud实用版》 Seata 分布式事务实战:AT / TCC / Saga /XA
后端·spring·spring cloud·seata·分布式事务
iRuriCatt1 小时前
智慧景区管理系统 | 计算机毕设项目
java·前端·spring boot·vue·毕设
FAFU_kyp1 小时前
RISC0_ZERO项目在macOs上生成链上证明避坑
开发语言·后端·学习·macos·rust
天空属于哈夫克31 小时前
企业微信外部群运营升级:API 主动推送消息开发实战
java·数据库·mysql
qq_12498707531 小时前
基于springboot的会议室预订系统设计与实现(源码+论文+部署+安装)
java·vue.js·spring boot·后端·信息可视化·毕业设计·计算机毕业设计
愿你天黑有灯下雨有伞1 小时前
java动态渲染列导出以及分页列表
java
星火开发设计1 小时前
共用体 union:节省内存的特殊数据类型
java·开发语言·数据库·c++·算法·内存
2301_803554522 小时前
阻塞,非阻塞,同步,异步以及linux上的5种IO模型阻塞,非阻塞,信号驱动,异步,IO复用
java·服务器·网络