Java Bean参数验证:深入探索javax.validation.constraints注解

简介: Java Bean参数验证:深入探索javax.validation.constraints注解

在Java应用开发中,尤其是涉及到Web服务和数据处理时,确保传入的数据符合预期是非常重要的。javax.validation.constraints包提供了一系列强大的注解,用于简化这一过程。这些注解基于JSR 303/JSR 349规范,能够帮助开发者以声明式的方式执行参数验证,而无需手动编写复杂的校验逻辑。下面我们将逐一介绍这些注解,并提供示例说明其适用场景和字段类型。

1. 布尔值验证

@AssertFalse

  • 用途:确保被注解的字段必须为false
  • 适用字段类型boolean, Boolean
  • 示例
@AssertFalse
private boolean inactive;

@AssertTrue

  • 用途:确保被注解的字段必须为true
  • 适用字段类型boolean, Boolean
  • 示例
@AssertTrue
private boolean isActive;

2. 数值范围验证

@DecimalMax(value)

  • 用途:限制数值最大值(包括小数)。
  • 适用字段类型BigDecimal, BigInteger, double, float
  • 示例
@DecimalMax("99.99")
private BigDecimal price;

@DecimalMin(value)

  • 用途:限制数值最小值(包括小数)。
  • 适用字段类型:同上
  • 示例
@DecimalMin("1.00")
private double discount;

@Digits(integer, fraction)

  • 用途:控制数字的整数部分和小数部分位数。
  • 适用字段类型:同上
  • 示例
@Digits(integer=5, fraction=2)
private float measurement;

@Max(value)

  • 用途:限制数值最大值(整数)。
  • 适用字段类型byte, short, int, long, BigDecimal, BigInteger
  • 示例
@Max(100)
private int quantity;

@Min(value)

  • 用途:限制数值最小值(整数)。
  • 适用字段类型:同上
  • 示例
@Min(0)
private long serialNumber;

@Negative

  • 用途:确保数值为负。
  • 适用字段类型:同上(不包括BigDecimal, BigInteger的小数情况)
  • 示例
@Negative
private int temperatureDelta;

@NegativeOrZero

  • 用途:确保数值为负或零。
  • 适用字段类型:同上
  • 示例
@N@NegativeOrZero
private short adjustment;

@Positive

  • 用途:确保数值为正。
  • 适用字段类型:同上
  • 示例
@Positive
private long populationCount;

@PositiveOrZero

  • 用途:确保数值为正或零。
  • 适用字段类型:同上
  • 示例
@PositiveOrZero
private int score;

3. 字符串和集合验证

@Email

  • 用途:验证字符串是否符合电子邮件地址的格式。
  • 适用字段类型String
  • 示例
@Email
private String userEmail;

@Future

  • 用途:确保日期在未来。
  • 适用字段类型Date, LocalDate, LocalDateTime, ZonedDateTime
  • 示例
@Future
private LocalDate expirationDate;

@FutureOrPresent

  • 用途:确保日期在未来或现在。
  • 适用字段类型:同上
  • 示例
@FutureOrPresent
private LocalDateTime lastUpdate;


@NotBlank

  • 用途:确保字符串非空且不只包含空白字符。
  • 适用字段类型CharSequence(如String
  • 示例
@NotBlank
private String password;

@NotEmpty

  • 用途:确保集合、数组或字符串非空。
  • 适用字段类型Array, Collection, Map, CharSequence
  • 示例
@NotEmpty
private List<String> tags;

@NotNull

  • 用途:确保字段不为null
  • 适用字段类型:所有类型
  • 示例
@NotNull
private User createdBy;

@Null

  • 用途:确保字段为null
  • 适用字段类型:所有类型
  • 示例
@Null
private transient String temporaryData;

@Past

  • 用途:确保日期在过去。
  • 适用字段类型:同日期相关类型
  • 示例
@Past
private Date birthDate;

@PastOrPresent

  • 用途:确保日期在过去或现在。
  • 适用字段类型:同上
  • 示例
@PastOrPresent
private LocalDateTime createdAt;

@Pattern(regexp)

  • 用途:使用正则表达式匹配字符串。
  • 适用字段类型CharSequence
  • 示例
@Pattern(regexp = "^\\d{3}-\\d{2}-\\d{4}$")
private String ssn;

@Size(min, max)

  • 用途:限制字符串、集合、数组的长度。
  • 适用字段类型Array, Collection, Map, CharSequence
  • 示例
@Size(min = 6, max = 20)
private String username;

以上注解大大简化了Java Bean参数的验证工作,提高了代码的可读性和维护性。在Spring Boot等框架中,它们通常与方法参数验证、数据绑定机制结合使用,为API开发提供了强大的支持。

相关文章
|
1月前
|
XML Java 编译器
Java注解的底层源码剖析与技术认识
Java注解(Annotation)是Java 5引入的一种新特性,它提供了一种在代码中添加元数据(Metadata)的方式。注解本身并不是代码的一部分,它们不会直接影响代码的执行,但可以在编译、类加载和运行时被读取和处理。注解为开发者提供了一种以非侵入性的方式为代码提供额外信息的手段,这些信息可以用于生成文档、编译时检查、运行时处理等。
65 7
|
3月前
|
XML Java 编译器
Java学习十六—掌握注解:让编程更简单
Java 注解(Annotation)是一种特殊的语法结构,可以在代码中嵌入元数据。它们不直接影响代码的运行,但可以通过工具和框架提供额外的信息,帮助在编译、部署或运行时进行处理。
111 43
Java学习十六—掌握注解:让编程更简单
|
1月前
|
Java 编译器 数据库
Java 中的注解(Annotations):代码中的 “元数据” 魔法
Java注解是代码中的“元数据”标签,不直接参与业务逻辑,但在编译或运行时提供重要信息。本文介绍了注解的基础语法、内置注解的应用场景,以及如何自定义注解和结合AOP技术实现方法执行日志记录,展示了注解在提升代码质量、简化开发流程和增强程序功能方面的强大作用。
87 5
|
2月前
|
Java
实现java执行kettle并传参数
实现java执行kettle并传参数
34 1
|
2月前
|
Java 开发者 Spring
[Java]自定义注解
本文介绍了Java中的四个元注解(@Target、@Retention、@Documented、@Inherited)及其使用方法,并详细讲解了自定义注解的定义和使用细节。文章还提到了Spring框架中的@AliasFor注解,通过示例帮助读者更好地理解和应用这些注解。文中强调了注解的生命周期、继承性和文档化特性,适合初学者和进阶开发者参考。
78 14
|
2月前
|
Java
在Java中定义一个不做事且没有参数的构造方法的作用
Java程序在执行子类的构造方法之前,如果没有用super()来调用父类特定的构造方法,则会调用父类中“没有参数的构造方法”。因此,如果父类中只定义了有参数的构造方法,而在子类的构造方法中又没有用super()来调用父类中特定的构造方法,则编译时将发生错误,因为Java程序在父类中找不到没有参数的构造方法可供执行。解决办法是在父类里加上一个不做事且没有参数的构造方法。
|
3月前
|
存储 网络协议 前端开发
在 Java 中如何完全验证 URL
在 Java 中如何完全验证 URL
104 8
|
3月前
|
存储 算法 Java
java制作海报六:Graphics2D的RenderingHints方法参数详解,包括解决文字不清晰,抗锯齿问题
这篇文章是关于如何在Java中使用Graphics2D的RenderingHints方法来提高海报制作的图像质量和文字清晰度,包括抗锯齿和解决文字不清晰问题的技术详解。
105 0
java制作海报六:Graphics2D的RenderingHints方法参数详解,包括解决文字不清晰,抗锯齿问题
|
2月前
|
Java 编译器
Java进阶之标准注解
Java进阶之标准注解
46 0
|
3月前
|
Java
java构造方法时对象初始化,实例化,参数赋值
java构造方法时对象初始化,实例化,参数赋值
96 1