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

相关推荐
孟沐2 小时前
Java 面向对象核心知识点(封装 / 继承 / 重写 / 多态)
后端
工边页字2 小时前
面试官:请详细介绍下AI中的token,越详细越好!
前端·人工智能·后端
LSTM972 小时前
确保文档安全:使用 C# 加密 Word 文档或设置文档权限
后端
孟沐2 小时前
Java 方法与方法重载
后端
Nyarlathotep01133 小时前
LinkedList源码分析
java·后端
小林coding3 小时前
专为程序员打造的简历模版来啦!覆盖前端、后端、测开、大模型等专业简历
前端·后端
UrbanJazzerati3 小时前
当网页翻页时,页码藏在哪里?——一次对分页机制的解密之旅
后端·面试
用户4490412095563 小时前
一次生产环境下的Redis连接耗尽问题排查与解决全过程
后端
Tapir3 小时前
被 Karpathy 下场推荐的 NanoClaw 是什么来头
前端·后端·github
ssshooter4 小时前
Tauri 项目实践:客户端与 Web 端的授权登录实现方案
前端·后端·rust