欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 房产 > 建筑 > 优雅的参数校验(@Validated)

优雅的参数校验(@Validated)

2025/6/23 17:09:55 来源:https://blog.csdn.net/Cosmoshhhyyy/article/details/148812399  浏览:    关键词:优雅的参数校验(@Validated)

在 Spring Boot 项目里,@Validated注解主要用于实现方法参数的校验。它既可以用在类级别,开启方法参数校验功能,也能应用于方法参数上,对传入的参数进行校验。

首先,要在项目中添加校验依赖。如果你使用的是spring-boot-starter-web,就无需额外添加依赖,因为它已经包含了hibernate-validator

对于需要校验的对象添加注解:

  • 1. 空值检查

    注解功能描述
    @Null被注释的元素必须为 null
    @NotNull被注释的元素必须不为 null,但可以是空字符串或空集合。
    @NotEmpty被注释的字符串、集合、数组或 Map 必须不为 null 且长度 / 大小大于 0。
    @NotBlank被注释的字符串必须不为 null,且至少包含一个非空白字符。

    2. 数值检查

    注解功能描述
    @Min(value)被注释的数值必须大于或等于指定的最小值(适用于数字类型)。
    @Max(value)被注释的数值必须小于或等于指定的最大值(适用于数字类型)。
    @DecimalMin(value)被注释的数值必须大于或等于指定的小数值(字符串表示,避免精度问题)。
    @DecimalMax(value)被注释的数值必须小于或等于指定的小数值(字符串表示,避免精度问题)。
    @Digits(integer, fraction)被注释的数值必须是数字,且整数部分位数不超过 integer,小数部分不超过 fraction
    @Positive被注释的数值必须是正数(不包括 0)。
    @PositiveOrZero被注释的数值必须是正数或 0。
    @Negative被注释的数值必须是负数(不包括 0)。
    @NegativeOrZero被注释的数值必须是负数或 0。

    3. 字符串检查

    注解功能描述
    @Size(min, max)被注释的字符串、集合、数组或 Map 的大小必须在指定范围内。
    @Pattern(regexp)被注释的字符串必须符合指定的正则表达式。
    @Email被注释的字符串必须是合法的电子邮件地址。

    4. 布尔检查

    注解功能描述
    @AssertTrue被注释的元素必须为 true
    @AssertFalse被注释的元素必须为 false

    5. 日期 / 时间检查

    注解功能描述
    @Future被注释的日期 / 时间必须是将来的时间(如 java.util.DateLocalDate 等)。
    @FutureOrPresent被注释的日期 / 时间必须是现在或将来的时间。
    @Past被注释的日期 / 时间必须是过去的时间。
    @PastOrPresent被注释的日期 / 时间必须是过去或现在的时间。

    6. 其他常用注解

    注解功能描述
    @Valid递归验证对象的所有字段(用于嵌套校验,如集合中的对象或对象的属性)。
    @CreditCardNumber被注释的字符串必须通过 Luhn 算法校验(信用卡号格式)。
    @URL被注释的字符串必须是合法的 URL。
    @Length(min, max)被注释的字符串长度必须在指定范围内(等效于 @Size,但仅用于字符串)。
    @Range(min, max)被注释的数值必须在指定范围内(适用于数字类型)。

    Jakarta Bean Validation 3.0(JSR 380)新增注解

    注解功能描述
    @NotEmpty替代 JSR-303 中的 @NotNull 和 @Size(min=1) 的组合(Jakarta EE 9+)。
    @NotBlank校验字符串非空且至少有一个非空白字符(Jakarta EE 9+)。
    @Positive/@PositiveOrZero校验正数或非负数(Jakarta EE 9+)。
    @Negative/@NegativeOrZero校验负数或非正数(Jakarta EE 9+)。

将需要用到的注解加入到对应字段即可。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词