Spring Validation 详解

更好的阅读体验 \huge{\color{red}{更好的阅读体验}} 更好的阅读体验

校验框架


SpringBoot 的 Validation:

  • Spring Boot中的验证功能是基于Java Bean Validation(Jakarta Validation)规范的
  • Spring Boot 通过 spring-boot-starter-validation 自动配置,实际使用的是 Hibernate Validator 作为其实现

Java Bean Validation:

  • Java Bean Validation 是JSR 303和JSR 380的一个执行标准(早期是JSR303,更新后是JSR380)
  • 定义了一套用于对象属性验证的 API 和注解,这个标准本身不提供具体的实现,只定义了规范
  • 在Java EE技术迁移到 Jakarta EE 之后,Java Bean Validation 变成了 Jakarta Validation

Hibernate Validator:

  • Hibernate Validator 是 Jakarta Validation 规范的参考实现
  • 它提供了该规范的完整实现,并且扩展了部分功能,使得验证更加灵活和强大

综上所述,SpringBoot 的 Validation 实际执行的是 Hibernate Validator,通过 Jakarta Validation API 对其进行了一层封装。


常用注解


@Size


  • 用法: 用于验证字符串、集合、数组等的长度或大小。

  • 属性:

    • min: 最小长度或大小(默认值为0)。
    • max: 最大长度或大小(默认值为Integer.MAX_VALUE)。
  • 示例:

    @Size(min = 3, max = 10)
    private String name;
    

@Min


  • 用法: 用于验证数值型字段的值不小于指定的最小值。

  • 属性:

    • value: 最小值。
  • 示例:

    @Min(18)
    private int age;
    

@Max


  • 用法: 用于验证数值型字段的值不大于指定的最大值。

  • 属性:

    • value: 最大值。
  • 示例:

    @Max(100)
    private int score;
    

@Null


  • 用法: 用于验证字段必须为null

  • 示例:

    @Null
    private String middleName;
    

@NotNull


  • 用法: 用于验证字段不能为null

  • 示例:

    @NotNull
    private String firstName;
    

@NotEmpty


  • 用法: 用于验证字符串、集合、数组等不能为null且必须有元素(即非空)。

  • 示例:

    @NotEmpty
    private List<String> items;
    

@NotBlank

  • 用法: 用于验证字符串不能为null,且去除空白字符后长度必须大于0。

  • 示例:

    @NotBlank
    private String username;
    

@Pattern


  • 用法: 用于验证字符串字段必须符合指定的正则表达式。

  • 属性:

    • regexp: 正则表达式。
    • flags: 正则表达式的匹配标志(可选)。
  • 示例:

    @Pattern(regexp = "^[a-zA-Z0-9]+$")
    private String alphanumeric;
    

@DecimalMin

  • 用法: 用于验证数值型字段的值不小于指定的最小值(支持小数)。

  • 属性

    :

    • value: 最小值。
    • inclusive: 是否包含最小值,默认为true(包含)。
  • 示例

    :

    @DecimalMin(value = "0.1", inclusive = false)
    private double price;
    

@DecimalMax

  • 用法: 用于验证数值型字段的值不大于指定的最大值(支持小数)。

  • 属性:

    • value: 最大值。
    • inclusive: 是否包含最大值,默认为true(包含)。
  • 示例:

    @DecimalMax(value = "100.0", inclusive = true)
    private double percentage;
    

@Digits

  • 用法: 用于验证数值型字段的整数位数和小数位数。

  • 属性:

    • integer: 最大整数位数。
    • fraction: 最大小数位数。
  • 示例:

    @Digits(integer = 5, fraction = 2)
    private BigDecimal amount;
    

@Email

  • 用法: 用于验证字符串字段是否符合电子邮件地址的格式。

  • 属性:

    • regexp: 正则表达式,默认是一个简单的电子邮件格式。
    • flags: 正则表达式的匹配标志(可选)。
  • 示例:

    @Email
    private String email;
    

@Future

  • 用法: 用于验证日期或时间字段的值必须在将来。

  • 示例:

    @Future
    private LocalDate expirationDate;
    

全局异常解析


当校验异常时,会抛出 MethodArgumentNotValidException 异常,可以对其添加全局的异常解析:

@ExceptionHandler(MethodArgumentNotValidException.class)
public Map<String, String> handleValidationExceptions(
  MethodArgumentNotValidException ex) {
    Map<String, String> errors = new HashMap<>();
    ex.getBindingResult().getAllErrors().forEach((error) -> {
        String fieldName = ((FieldError) error).getField();
        String errorMessage = error.getDefaultMessage();
        errors.put(fieldName, errorMessage);
    });
    return errors;
}
  • 24
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

浪漫主义狗

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值