Java中常见的数据验证注解总结大全

 更新时间:2025年07月11日 10:32:02   作者:你好胖同学  
在Java开发中数据校验是确保应用程序的数据完整性和一致性的重要步骤,这篇文章主要介绍了Java中常见的数据验证注解的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下

1.@Length

  • 功能:@Length 用于验证字符串的长度是否在指定的范围内。

  • 适用场景:它只适用于字符串类型的字段。该注解可以用来限制字符串的最小长度和最大长度。

  • 常见用途:验证用户输入的文本(例如用户名、密码等)的长度是否满足要求。

示例:

import org.hibernate.validator.constraints.Length;

public class User {
    
    @Length(min = 5, max = 15, message = "Username must be between 5 and 15 characters")
    private String username;
    
    // getters and setters
}
  • 在这个例子中,@Length(min = 5, max = 15) 表示 username 字段的长度必须在 5 到 15 个字符之间。

2.@Range

  • 功能:@Range 用于验证数字(如 intlongBigDecimal 等)是否在指定的范围内。

  • 适用场景:它通常用于数值类型的数据(如整数或浮动小数)。你可以指定数值的最小值和最大值。

  • 常见用途:验证用户输入的数字(例如年龄、评分等)是否在一个合理的范围内。

示例:

import org.hibernate.validator.constraints.Range;

public class Product {
    
    @Range(min = 1, max = 10000, message = "Price must be between 1 and 10000")
    private int price;
    
    // getters and setters
}
  • 在这个例子中,@Range(min = 1, max = 10000) 表示 price 字段的值必须在 1 到 10,000 之间。

主要区别:

特性@Length@Range
验证类型用于验证字符串的长度范围用于验证数值(如整数、浮点数)的范围
适用数据类型字符串(String数字(intlongBigDecimal 等)
常见用途限制文本长度(例如用户名、密码等)限制数字值(例如价格、年龄等)

总结:

  • @Length 是针对字符串类型的长度验证,主要用于限制字符串的最小和最大长度。

  • @Range 是针对数值类型的范围验证,主要用于限制数字的最小和最大值

3.@NotNull

  • 功能:@NotNull 用于验证一个字段的值是否为 null。如果该字段的值为 null,则验证失败。

  • 适用场景:它适用于所有类型的字段(包括字符串、数字、对象等),用来确保该字段不能为 null

  • 注意:@NotNull 不会验证空字符串 ("")、空集合或空数组,它只关注字段是否为 null

示例:

import javax.validation.constraints.NotNull;

public class User {
    
    @NotNull(message = "Username cannot be null")
    private String username;
    
    // getters and setters
}
  • 在这个例子中,@NotNull 确保 username 字段的值不能为 null。如果它是 null,验证将失败。

4.@NotBlank

  • 功能:@NotBlank 用于验证一个字符串字段不能为 null、不能为空字符串(""),并且不能只包含空白字符(如空格、制表符等)。它比 @NotNull 更严格,确保字符串不仅非空,还必须包含至少一个非空白字符。

  • 适用场景:它专门用于字符串类型的字段,确保字符串有有效的内容。

  • 注意:@NotBlank 不仅会验证 null,还会验证字符串是否为空或者只包含空格。

示例:

import javax.validation.constraints.NotBlank;

public class User {
    
    @NotBlank(message = "Username cannot be blank")
    private String username;
    
    // getters and setters
}
  • 在这个例子中,@NotBlank 确保 username 字段的值不能为 null,也不能是一个空字符串或只包含空白字符。如果是,验证将失败。

主要区别:

特性@NotNull@NotBlank
验证内容仅验证字段是否为 null验证字段是否为 null 或空白字符串(包括只包含空格)
适用类型适用于任何类型的字段(StringInteger、对象等)仅适用于字符串类型的字段(String
验证条件只关注字段是否为 null确保字段非 null 且包含至少一个非空白字符
常见用途确保字段的值不能为 null确保字符串字段非空且不为空白

总结:

  • @NotNull 主要用来确保字段不为 null,适用于任何类型的字段。

  • @NotBlank 主要用于字符串类型的字段,确保字段不仅不为 null,而且不为空字符串,也不包含仅空白字符。

使用场景:

  • 如果你想验证某个字段不能为 null,使用 @NotNull

  • 如果你想验证某个字符串字段不能为 null 或者空白字符串,使用 @NotBlank

5.@Min

  • 功能:@Min 用于验证数值(如整数、浮点数等)是否大于或等于指定的最小值。

  • 适用场景:适用于基本数值类型(如 intlongfloatdouble 及其包装类),以及字符串表示的数值(需确保字符串可转换为数值类型)。

  • 常见用途:验证年龄下限、金额最小值、数量下限等场景。

示例:

import javax.validation.constraints.Min;

public class Product {
    
    @Min(value = 0, message = "Price cannot be negative")
    private double price;
    
    // getters and setters
}
  • 在这个例子中,@Min(value = 0) 表示 price 字段的值必须大于或等于 0。

6.@Max

  • 功能:@Max 用于验证数值是否小于或等于指定的最大值。

  • 适用场景:与 @Min 类似,适用于基本数值类型及可转换为数值的字符串。

  • 常见用途:验证年龄上限、金额最大值、数量上限等场景。

示例:

import javax.validation.constraints.Max;

public class AgeVerification {
    
    @Max(value = 150, message = "Age cannot exceed 150")
    private Integer age;
    
    // getters and setters
}
  • 在这个例子中,@Max(value = 150) 表示 age 字段的值必须小于或等于 150。

7.@Size

  • 功能:@Size 用于验证集合(如 ListSet)、数组或字符串的大小(长度)是否在指定范围内。

  • 适用场景:适用于字符串、集合类、数组等可计算大小的对象。

  • 常见用途:验证列表长度、字符串长度、数组大小等场景。

示例:

import javax.validation.constraints.Size;
import java.util.List;

public class ShoppingCart {
    
    @Size(min = 1, max = 10, message = "Must select between 1 and 10 items")
    private List<String> items;
    
    // getters and setters
}
  • 在这个例子中,@Size(min = 1, max = 10) 表示 items 列表的元素数量必须在 1 到 10 之间。

总结

注解适用类型验证逻辑示例参数
@Min数值类型(及可转换为数值的字符串)最小值约束(≥ 指定值)@Min(18)
@Max数值类型(及可转换为数值的字符串)最大值约束(≤ 指定值)@Max(100)
@Size字符串、集合、数组大小/长度约束(min ≤ size ≤ max)@Size(min=1, max=5)

到此这篇关于Java中常见数据验证注解的文章就介绍到这了,更多相关Java数据验证注解内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SpringBoot多模块项目中优雅实现自动配置的完整指南

    SpringBoot多模块项目中优雅实现自动配置的完整指南

    在 Spring Boot 开发中,自动配置 是一个绕不开的核心能力,本文将结合一个 RabbitService 自动配置的示例,完整讲解如何在 Spring Boot 多模块项目中实现自动配置,希望对大家有所帮助
    2026-02-02
  • 深入理解Struts2国际化信息机制

    深入理解Struts2国际化信息机制

    本篇文章主要介绍了深入理解Struts2国际化信息机制,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-07-07
  • Java虚拟机之类加载

    Java虚拟机之类加载

    这篇文章主要介绍了Java虚拟机之类加载,文中有非常详细的代码示例,对正在学习java的小伙伴们有很好地帮助,需要的朋友可以参考下
    2021-05-05
  • Spring注解@Autowired和@Resource的区别详解

    Spring注解@Autowired和@Resource的区别详解

    这篇文章主要介绍了Spring注解@Autowired和@Resource的区别详解,@Autowired与@Resource都可以用来装配bean,都可以写在字段或setter方法上,@Resource是JDK提供的注解,默认按照名称进行装配,名称可通过name属性进行指定,需要的朋友可以参考下
    2023-12-12
  • Java守护线程用法实例分析

    Java守护线程用法实例分析

    这篇文章主要介绍了Java守护线程用法,结合实例形式分析了java守护线程相关的原理、用法及相关操作注意事项,需要的朋友可以参考下
    2019-10-10
  • Java中GC的工作原理详细介绍

    Java中GC的工作原理详细介绍

    这篇文章主要介绍了Java中GC的工作原理详细介绍的相关资料,需要的朋友可以参考下
    2017-03-03
  • Java中的Object类用法总结

    Java中的Object类用法总结

    Java是一种面向对象的编程语言,它提供了一个非常强大的类库,其中一个基本类是Object类,下面这篇文章主要给大家介绍了Java中Object类用法的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-04-04
  • Intellij IDEA 关闭和开启自动更新的提示?

    Intellij IDEA 关闭和开启自动更新的提示?

    这篇文章主要介绍了Intellij IDEA 关闭和开启自动更新的提示操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-04-04
  • IDEA生成项目maven-tree依赖目录树结构方式

    IDEA生成项目maven-tree依赖目录树结构方式

    这篇文章主要介绍了IDEA生成项目maven-tree依赖目录树结构方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • Lombok中@Accessors注解的使用及说明

    Lombok中@Accessors注解的使用及说明

    Lombok是一个Java库,旨在通过注解减少代码量,提高效率,@Accessors注解是其中一种工具,用于简化Java类的访问器方法,这个注解允许配置访问器的生成方式,包括是否使用fluent风格、是否忽略字段前缀以及是否支持链式调用,从而使代码更简洁、易读
    2025-10-10

最新评论