SpringBoot 的 Validation:
spring-boot-starter-validation
自动配置,实际使用的是 Hibernate Validator 作为其实现Java Bean Validation:
Hibernate Validator:
综上所述,SpringBoot 的 Validation 实际执行的是 Hibernate Validator,通过 Jakarta Validation API 对其进行了一层封装。
用法: 用于验证字符串、集合、数组等的长度或大小。
属性:
min
: 最小长度或大小(默认值为0)。max
: 最大长度或大小(默认值为Integer.MAX_VALUE)。示例:
@Size(min = 3, max = 10)
private String name;
用法: 用于验证数值型字段的值不小于指定的最小值。
属性:
value
: 最小值。示例:
@Min(18)
private int age;
用法: 用于验证数值型字段的值不大于指定的最大值。
属性:
value
: 最大值。示例:
@Max(100)
private int score;
用法: 用于验证字段必须为null
。
示例:
@Null
private String middleName;
用法: 用于验证字段不能为null
。
示例:
@NotNull
private String firstName;
用法: 用于验证字符串、集合、数组等不能为null
且必须有元素(即非空)。
示例:
@NotEmpty
private List items;
用法: 用于验证字符串不能为null
,且去除空白字符后长度必须大于0。
示例:
@NotBlank
private String username;
用法: 用于验证字符串字段必须符合指定的正则表达式。
属性:
regexp
: 正则表达式。flags
: 正则表达式的匹配标志(可选)。示例:
@Pattern(regexp = "^[a-zA-Z0-9]+$")
private String alphanumeric;
用法: 用于验证数值型字段的值不小于指定的最小值(支持小数)。
属性
:
value
: 最小值。inclusive
: 是否包含最小值,默认为true
(包含)。示例:
@DecimalMin(value = "0.1", inclusive = false)
private double price;
用法: 用于验证数值型字段的值不大于指定的最大值(支持小数)。
属性:
value
: 最大值。inclusive
: 是否包含最大值,默认为true
(包含)。示例:
@DecimalMax(value = "100.0", inclusive = true)
private double percentage;
用法: 用于验证数值型字段的整数位数和小数位数。
属性:
integer
: 最大整数位数。fraction
: 最大小数位数。示例:
@Digits(integer = 5, fraction = 2)
private BigDecimal amount;
用法: 用于验证字符串字段是否符合电子邮件地址的格式。
属性:
regexp
: 正则表达式,默认是一个简单的电子邮件格式。flags
: 正则表达式的匹配标志(可选)。示例:
@Email
private String email;
用法: 用于验证日期或时间字段的值必须在将来。
示例:
@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;
}