当前位置: 首页 > news >正文

【@NotBlank】@NotBlank与@NotEmpty与@NotNull区别

这里写目录标题

  • 🎯 核心定义
  • 📊 与其他注解的区别
  • 💻 代码示例
  • 🛠️ 如何使用
  • 💡 适用场景建议

@NotBlank 是 Java Bean Validation(数据校验)中一个非常常用的注解,主要用于严格校验字符串。

🎯 核心定义

@NotBlank 专门用于String(字符串)类型的字段或参数。
它的校验逻辑非常严格,要求被注解的字符串必须同时满足以下三个条件:
不能为 null。
不能是空字符串 “”。
不能是纯空白字符(例如:" “、”\t"、“\n” 等,即去除首尾空格后长度必须大于 0)。

📊 与其他注解的区别

为了方便你记忆,我整理了一个对比表格。这是 @NotBlank 最容易混淆的三个注解:

注解适用类型校验严格度能否通过纯空格" "
@NotNull所有对象最宽松能 (只检查 null)
@NotEmpty字符串、集合、数组中等能 (只检查长度/大小)
@NotBlank仅字符串最严格不能 (会 trim() 后检查)

一句话总结区别:
@NotNull 只管“有没有”(不为 null)。
@NotEmpty 管“是不是空的”(长度/大小 > 0)。
@NotBlank 管“是不是真的有内容”(必须有非空格字符)。

💻 代码示例

假设我们有一个用户注册的场景:

publicclassUser{// 只要不为 null 就行,可以是 "" 或 " "@NotNullprivateStringfield1;// 不能为 null,且长度必须 > 0,所以 " " 是允许的@NotEmptyprivateStringfield2;// 不能为 null,不能是 "",且不能是 " " (纯空格会被视为无效)@NotBlankprivateStringusername;// getter and setter...}

测试数据验证结果:

输入值@NotNull@NotEmpty@NotBlank
null❌ 失败❌ 失败❌ 失败
""(空字符串)✅ 通过❌ 失败❌ 失败
" "(纯空格)✅ 通过✅ 通过❌ 失败
"abc"(正常内容)✅ 通过✅ 通过✅ 通过

🛠️ 如何使用

在 Spring Boot 项目中,通常配合 @Valid 或 @Validated 使用。
引入依赖(通常 Spring Boot Starter 已包含):

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-validation</artifactId></dependency>

在实体类或 Controller 参数上使用:

@RestController@ValidatedpublicclassUserController{@PostMapping("/register")publicStringregister(@RequestBody@ValidUseruser){// 业务逻辑return"success";}}

如果前端传入的 username 是 null、“” 或 " ",框架会自动拦截并抛出异常,不会进入业务逻辑。

💡 适用场景建议

使用 @NotBlank:用于业务必填且必须有意义的文本字段,如:用户名、密码、真实姓名、地址、备注等。防止用户“偷懒”只输入空格。
使用 @NotEmpty:用于集合(List/Set)判空,或者字符串只要求长度大于 0(允许空格)的特殊场景。
使用 @NotNull:用于 Long、Integer 等包装类,或者日期类型,或者你只关心对象是否存在而不关心内容的场景。

http://www.cnnetsun.cn/news/2698.html

相关文章:

  • 12、Kubernetes服务部署与管理全解析
  • 13、使用Mesosphere管理和部署Docker应用
  • 14、容器编排工具:Mesosphere、Fleet与Cattle使用指南
  • 15、使用更简单的编排工具:Fleet和Cattle
  • 16、使用简化的编排工具:Fleet 和 Rancher
  • 17、集群监控:工具与实践
  • 18、容器监控与持续集成实践指南
  • 19、使用持续集成构建、测试和部署容器
  • 20、使用持续集成构建、测试和部署容器及自动化基础设施
  • 21、超越容器:自动化基础设施管理
  • 基于滑模观测器(smo)锁相环pll的无位置传感器的永磁同步电机spmsm的矢量控制simul...
  • 4.React组件状态管理
  • 34、Perl 中的 Unicode 处理全解析
  • 35、Perl 中的 Unicode 处理全解析
  • 37、Perl 中的 Unicode 字符属性与编码教程
  • 38、Perl编程:字符串、编码、工具与预定义变量全解析
  • 39、Perl特殊变量全解析
  • 40、Perl 特殊变量详解
  • 41、Perl在VMS系统上的使用指南
  • 42、Perl 在 VMS 系统中的函数与变量使用指南
  • 43、技术工具与编程语言使用指南
  • 44、技术工具使用指南:从图形转换到信息查看
  • Wan2.2-T2V-5B能否用于电影分镜快速预演?影视制作提效路径
  • AI视频生成进入平民化时代:Wan2.2-T2V-5B带来新可能
  • 电压环PI调节器示例
  • AI知识表示的演变:从向量时代 -> 图时代 -> 混合时代!
  • 为什么Crypto是AI Agent大规模落地的关键基础设施?
  • VFP 免注册多线程技术,无需注册,使用方便
  • 技术时刻丨正则表达式次数符号“{}“在Oracle和openGauss中的差异
  • Wan2.2-T2V-5B如何参与贡献?GitHub开发指南