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

相关推荐
我登哥MVP2 分钟前
SpringCloud Alibaba 核心组件解析:分布式事务(Seata)
java·spring boot·分布式·spring·spring cloud·java-ee·intellij-idea
java_cj6 分钟前
从kubectl源码学Cobra:打造专业级Go命令行工具的完整实践
运维·开发语言·后端·云原生·golang·kubernetes·k8s
copyer_xyf13 分钟前
Agent MCP
后端·python·agent
摇滚侠43 分钟前
MyBatis 入门到项目实战 MyBatis 各种查询功能 30-33
java·后端·spring·maven·intellij-idea·mybatis
JustHappy9 小时前
古法编程秘籍(七):互联网到底是什么?把两台电脑怎么说话搞懂就够了
前端·后端·网络协议
Hommy889 小时前
【剪映小助手】添加图片接口(Add Images)
后端·github·剪映小助手·视频剪辑自动化
GetcharZp10 小时前
别再盲目用 OpenCV 读图了,这才是 CV 预处理的终极杀手锏!
后端
一 乐13 小时前
家政服务管理系统|基于springboot + vue家政服务管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·家政服务管理系统
IT_陈寒13 小时前
Vite热更新失效?可能你在用Windows
前端·人工智能·后端
椰椰椰耶15 小时前
[SpringCloud][14]OpenFeign参数传递方法
后端·spring·spring cloud