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

相关推荐
devpotato2 小时前
Spring Boot mTLS 报 `keystore password was incorrect`:不一定是密码错了
spring boot·tls·pkcs12·mtls
古城小栈3 小时前
从 cargo-whero 库中,找到提升 rust 的契机
开发语言·后端·rust
keep one's resolveY4 小时前
SpringBoot实现重试机制的四种方案
java·spring boot·后端
阿丰资源6 小时前
基于Spring Boot的电影城管理系统(直接运行)
java·spring boot·后端
IT_陈寒6 小时前
SpringBoot自动配置的坑差点让我加班到天亮
前端·人工智能·后端
消失的旧时光-19437 小时前
Spring Boot 工程化进阶:统一返回 + 全局异常 + AOP 通用工具包
java·spring boot·后端·aop·自定义注解
追风筝的人er7 小时前
SpringBoot+Vue3 企业考勤如何处理法定假期?节假日方案、调休补班与工作日判断链路拆解
前端·vue.js·后端
StockTV8 小时前
印度股票实时数据 NSE和BSE的实时行情、K 线及指数数据
java·开发语言·spring boot·python
金銀銅鐵8 小时前
[git] 如何丢弃对一个文件的改动?
git·后端