Spring Boot 项目中判断集合(List、Set、Map)不能为空且不为 null的注解使用

在 Spring Boot (结合 Bean Validation / Hibernate Validator) 中,判断集合(List、Set、Map)不能为空且不为 null,最常用且语义最准确的注解是 @NotEmpty

推荐写法

java 复制代码
import jakarta.validation.constraints.NotEmpty; // Spring Boot 3.x
// import javax.validation.constraints.NotEmpty; // Spring Boot 2.x 及以下

public class OrderRequest {

    @NotEmpty(message = "订单项ID集合不能为空")
    private List<Long> orderItemIds;

    // getter and setter...
}

为什么选 @NotEmpty?(与其他注解的对比)

注解 作用对象 行为描述 集合 [] (size=0) 集合 null 适用性
@NotEmpty CharSequence, Collection, Map, Array 非 null 且 size > 0 ❌ 报错 (拦截) ❌ 报错 (拦截) ✅ 最佳选择
@NotNull 任何对象 仅仅是非 null ✅ 通过 (不拦截) ❌ 报错 (拦截) ❌ 不够用 (允许空集合)
@Size(min=1) Collection, Map, Array, String size >= min ❌ 报错 (拦截) ✅ 通过 (通常视为有效,除非加@NotNull) ⚠️ 也可以用,但语义不如 NotEmpty 清晰
@NotBlank String (字符串) 非 null 且包含非空格字符 N/A N/A ❌ 仅限字符串,不能用于 List

注意事项

  1. 依赖引入

    从 Spring Boot 2.3 开始,Validation 启动器被独立出来了,如果你的项目中注解无法导入,需要手动在 pom.xml 中添加:

    xml 复制代码
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-validation</artifactId>
    </dependency>
  2. 触发验证

    注解加上后,必须在 Controller 层的方法参数前加上 @Valid@Validated 才会生效:

    java 复制代码
    @PostMapping("/create")
    public Result createOrder(@RequestBody @Valid OrderRequest request) {
        // ...
    }

总结:请直接使用 @NotEmpty

相关推荐
Mahir089 小时前
Spring 循环依赖深度解密:从问题本质到三级缓存源码级解析
java·后端·spring·缓存·面试·循环依赖·三级缓存
IT_陈寒13 小时前
Redis缓存击穿把我整不会了,原来还有这手操作
前端·人工智能·后端
kyriewen14 小时前
面试官让我查各部门工资最高的员工,我用AI三秒写出窗口函数,他愣了
后端·mysql·面试
文心快码BaiduComate14 小时前
干货|Comate Harness Engineering工程实践指南
前端·后端·程序员
光辉GuangHui14 小时前
Agent Skill 也需要测试:如何搭建 Skill 评估框架
前端·后端·llm
我是谁的程序员14 小时前
Mac 上生成 AppStoreInfo.plist 文件,App Store 上架
后端·ios
irving同学4623814 小时前
Node 后端实战:JWT 认证与生产级错误处理
前端·后端
Master_Azur14 小时前
单元测试——Junit单元测试框架
后端
用户83562907805114 小时前
使用 Python 进行 Word 邮件合并
后端
用户83562907805114 小时前
Python 操作 PowerPoint OLE 对象
后端·python