1、常用注解
- @NotNull :确保字段的值不能为
null。
java
@NotNull(message = "用户名不能为空")
private String username;
- @NotEmpty :确保字符串不能为
null或空字符串""。
java
@NotEmpty(message = "密码不能为空")
private String password;
- @NotBlank :确保字符串不能为
null或空格字符(包括空格、tab 等)。
java
@NotBlank(message = "用户名不能为空")
private String username;
- @Size:用于约束字符串、集合、数组的大小。
java
@Size(min = 5, max = 20, message = "用户名长度必须在 5 到 20 个字符之间")
private String username;
- @Min 和 @Max:用于对数字进行大小校验。
java
@Min(value = 18, message = "年龄必须大于等于 18 岁")
private int age;
@Max(value = 100, message = "年龄不能超过 100 岁")
private int age;
- @Email:用于校验邮箱格式。
java
@Email(message = "邮箱格式不正确")
private String email;
- @Pattern:用于校验字符串是否匹配正则表达式。
java
@Pattern(regexp = "^[A-Za-z0-9]+$", message = "用户名只能包含字母和数字")
private String username;
- @Range :用于数字范围校验(
@Min和@Max的组合)。
java
@Range(min = 18, max = 100, message = "年龄必须在 18 到 100 之间")
private int age;
- @AssertTrue 和 @AssertFalse:用于验证布尔值。
java
@AssertTrue(message = "必须为成年人")
private boolean isAdult;
- @Valid :用于嵌套对象的校验。通常在对象的属性为另一个对象时,使用
@Valid来触发子对象的校验。
java
public class User {
@Valid
private Address address;
}
2、Spring Boot中实现参数校验
2.1 引入依赖pom.xml
xml
<!-- 参数校验 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-validation</artifactId>
</dependency>
2.2 在实体类上添加校验注解
2.3 在Controller方法参数上添加@Validated
2.4 在全局异常处理中添加参数校验异常处理
java
@ExceptionHandler(MethodArgumentNotValidException.class)
public Result<String> handleValidationException(MethodArgumentNotValidException e) {
String message = e.getBindingResult().getFieldErrors().stream()
.map(error -> error.getField() + ": " + error.getDefaultMessage())
.collect(Collectors.joining("; "));
return Result.error(400, message);
}