Spring参数校验,数组入参校验 :List<E>

1、程序内直接校验

参数进入控制层方法,使用具体的参数方法来验证,灵活不优雅

复制代码
Objects.isNull()
String.isEmpty()

2、验证 单对象(Obj)使用 @Validated

优雅,不灵活,对象类配置多

首先在对象类中

1、校验属性添加注解

2、添加校验分组

复制代码
/**
 * @NotBlank 非nll 非空
 */
@NotBlank(message = "name不能为空", groups = {InsertGroup.class})
private String name;



/**
 * @NotNull 非空,这里是数组,不能要求非空字符串
 */
@Transient
@NotNull(message = "Ids不能为空", groups = {InsertGroup.class})
@JsonProperty(access = JsonProperty.Access.WRITE_ONLY)
private String[] Ids;

/**
 * 设置不同分组,供给不同的严正要求
 */
public interface InsertGroup {}

控制层使用@Validated验证

复制代码
/**
 * @Validated(OamUpg.InsertGroup.class) 这具体验证分组
 */
public AjaxResult insertTest(@Validated(TestObj.InsertGroup.class) @RequestBody TestObj obj)

经过这样设置就能在控制层对单对象的入参进行验参了

3、验证 数组对象(List)使用 @Validated+自定义工具类

首先确保单对象验证正确

Java对象

复制代码
@Data
@TableName(value = "product")
@Validated
public class TheCommodity {
    @TableId(value = "id", type = IdType.AUTO)
    private Integer id;

    @TableField(value = "product_name")
    @NotBlank(message = "productName cannot be empty!",groups = {addOne.class})
    private String productName;

    @TableField(value = "product_count")
    @NotBlank(message = "productCount cannot be empty!",groups = {addOne.class})
    private String productCount;

    @JsonProperty("tenant_id")  // 显式指定 JSON 字段名为 tenant_id
    @TableField(value = "tenant_id")
    @NotNull(message = "Tenant ID cannot be null!",groups = {addOne.class})
    private Integer tenantId;

    public interface addOne{}
}

控制层

复制代码
@PostMapping("/addOne")
public boolean addOne(@Validated(TheCommodity.addOne.class) @RequestBody TheCommodity product) {
    System.out.println("入参为 "+product.toString());
    return productService.save(product);
}

这个示例和2相同,通过@Validated 以及对象内部的判定注解,即可实现单对象的参数校验

现在自定义一个工具方法

复制代码
import javax.validation.*;
import java.util.List;
import java.util.Set;

public class ValidationUtil {

    private static Validator validator = Validation.buildDefaultValidatorFactory().getValidator();

    /**
     * 校验列表中的每个对象,并返回第一个校验失败的对象及错误信息
     *
     * @param list 待校验的对象列表
     * @param group 校验分组
     * @param <T> 对象类型
     * @return 校验失败的对象字符串和错误信息,或 "200" 表示通过
     */
    public static <T> String validateList(List<T> list, Class<?> group) {
        for (T item : list) {
            // 校验该对象
            Set<ConstraintViolation<T>> violations = validator.validate(item, group);

            // 如果校验失败,返回该对象的字符串打印和错误提示
            if (!violations.isEmpty()) {
                StringBuilder errorMessages = new StringBuilder();
                for (ConstraintViolation<T> violation : violations) {
                    errorMessages.append(violation.getMessage()).append(", ");
                }
                // 返回对象的字符串打印和错误信息
                return "对象: " + item.toString() + " 错误: " + errorMessages.toString();
            }
        }
        return "200";  // 如果没有错误,返回 "200"
    }
}

批量操作时调用这个方法,通过向工具类传参,

1、入参list

2、验参分组

复制代码
ValidationUtil.validateList(productList, TheCommodity.addOne.class);

控制层使用示例

复制代码
@PostMapping("/addBatch")
public boolean addBatch(@RequestBody List<TheCommodity> productList) {
    // 调用通用工具方法进行校验
    String result = ValidationUtil.validateList(productList, TheCommodity.addOne.class);

    if (!result.equals("200")) {
    	// 验参未通过,信息提示、记录等逻辑
        System.out.println(result);
        return false;
    }
	// 继续进行逻辑操作
	return true;
}

PS:这里我看了很多博客说使用@Valid 能递归到数组内,但是我各种尝试,始终没能验参成功。
所以这里暂时只能自己动手了,欢迎小伙伴们在评论区交流学习,指正错误。

相关推荐
LaughingZhu14 分钟前
Product Hunt 每日热榜 | 2026-05-04
人工智能·经验分享·深度学习·神经网络·产品运营
AI人工智能+电脑小能手16 分钟前
【大白话说Java面试题】【Java基础篇】第30题:JDK动态代理和CGLIB动态代理有什么区别
java·开发语言·后端·面试·代理模式
swipe27 分钟前
别再把 AI 聊天做成纯文本:从 agui 这个前后端项目,拆解“可感知工具调用”的流式 AI UI
后端·langchain·llm
GetcharZp29 分钟前
GitHub 爆火!纯 Go 编写的文件同步神器 Syncthing,凭什么成为程序员的标配?
后端
hERS EOUS32 分钟前
SpringBoot 使用 spring.profiles.active 来区分不同环境配置
spring boot·后端·spring
DFT计算杂谈38 分钟前
wannier90 参数详解大全
java·前端·css·html·css3
LucianaiB44 分钟前
我用飞书多维表做了一个 AI 活动推荐智能体:每天自动催我别错过截止日期!
后端
marsh02061 小时前
43 openclaw熔断与降级:保障系统在异常情况下的可用性
java·运维·网络·ai·编程·技术
张健11564096481 小时前
临界区和同一线程上锁
java·开发语言·jvm
天竺鼠不该去劝架2 小时前
AI+RPA 深度解析:从技术原理到行业落地,一篇读懂智能自动化核心密码
经验分享