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开发提供了强大的支持。

相关文章
|
XML Java 编译器
Java注解的底层源码剖析与技术认识
Java注解(Annotation)是Java 5引入的一种新特性,它提供了一种在代码中添加元数据(Metadata)的方式。注解本身并不是代码的一部分,它们不会直接影响代码的执行,但可以在编译、类加载和运行时被读取和处理。注解为开发者提供了一种以非侵入性的方式为代码提供额外信息的手段,这些信息可以用于生成文档、编译时检查、运行时处理等。
289 7
|
Java Linux 定位技术
Minecraft配置文件参数说明(JAVA服务器篇)
Minecraft JAVA版服务器启动后会生成server.properties配置文件,位于minecraft_server/根目录下。该文件包含多项关键设置,如游戏模式(gamemode)、最大玩家数(max-players)、难度(difficulty)等。此文档详细说明了各配置项的功能与默认值,帮助用户高效管理服务器环境。
3747 62
|
Java 编译器 开发者
注解的艺术:Java编程的高级定制
注解是Java编程中的高级特性,通过内置注解、自定义注解及注解处理器,可以实现代码的高度定制和扩展。通过理解和掌握注解的使用方法,开发者可以提高代码的可读性、可维护性和开发效率。在实际应用中,注解广泛用于框架开发、代码生成和配置管理等方面,展示了其强大的功能和灵活性。
315 25
|
XML Java 编译器
Java学习十六—掌握注解:让编程更简单
Java 注解(Annotation)是一种特殊的语法结构,可以在代码中嵌入元数据。它们不直接影响代码的运行,但可以通过工具和框架提供额外的信息,帮助在编译、部署或运行时进行处理。
399 43
Java学习十六—掌握注解:让编程更简单
java中一个接口A,以及一个实现它的类B,一个A类型的引用对象作为一个方法的参数,这个参数的类型可以是B的类型吗?
本文探讨了面向对象编程中接口与实现类的关系,以及里氏替换原则(LSP)的应用。通过示例代码展示了如何利用多态性将实现类的对象传递给接口类型的参数,满足LSP的要求。LSP确保子类能无缝替换父类或接口,不改变程序行为。接口定义了行为规范,实现类遵循此规范,从而保证了多态性和代码的可维护性。总结来说,接口与实现类的关系天然符合LSP,体现了多态性的核心思想。
700 0
|
Java 编译器 数据库
Java 中的注解(Annotations):代码中的 “元数据” 魔法
Java注解是代码中的“元数据”标签,不直接参与业务逻辑,但在编译或运行时提供重要信息。本文介绍了注解的基础语法、内置注解的应用场景,以及如何自定义注解和结合AOP技术实现方法执行日志记录,展示了注解在提升代码质量、简化开发流程和增强程序功能方面的强大作用。
568 5
|
Java
实现java执行kettle并传参数
实现java执行kettle并传参数
399 1
|
存储 算法 Java
java制作海报六:Graphics2D的RenderingHints方法参数详解,包括解决文字不清晰,抗锯齿问题
这篇文章是关于如何在Java中使用Graphics2D的RenderingHints方法来提高海报制作的图像质量和文字清晰度,包括抗锯齿和解决文字不清晰问题的技术详解。
761 0
java制作海报六:Graphics2D的RenderingHints方法参数详解,包括解决文字不清晰,抗锯齿问题
在Java中定义一个不做事且没有参数的构造方法的作用
Java程序在执行子类的构造方法之前,如果没有用super()来调用父类特定的构造方法,则会调用父类中“没有参数的构造方法”。因此,如果父类中只定义了有参数的构造方法,而在子类的构造方法中又没有用super()来调用父类中特定的构造方法,则编译时将发生错误,因为Java程序在父类中找不到没有参数的构造方法可供执行。解决办法是在父类里加上一个不做事且没有参数的构造方法。
|
Java 编译器
Java进阶之标准注解
Java进阶之标准注解
173 0