Spring Boot 参数校验

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);
}
相关推荐
黑眼圈子2 小时前
总结一下用Java做算法的常用类和方法
java·开发语言·算法
Magic--2 小时前
深入解析管道:最基础的进程间通信(IPC)实现
java·服务器·unix
架构师沉默2 小时前
为什么国外程序员都写独立博客,而国内都在公众号?
java·后端·架构
带刺的坐椅2 小时前
SolonCode v2026.4.1 发布(比 ClaudeCode 简约的编程智能体)
java·ai·llm·agent·solon-ai·claudecode·soloncode
殷紫川3 小时前
从单体到亿级流量:登录功能全场景设计指南,踩过的坑全给你填平了
java
Filwaod3 小时前
Cursor+IDEA开发问题
java·idea·cursor
爱丽_3 小时前
Spring 事务:传播行为、失效场景、回滚规则与最佳实践
java·后端·spring
Zzxy3 小时前
Spring Boot集成Swagger/Knife4j
spring boot·swagger
timi先生3 小时前
语料库全栈项目部署 (Vue + Java + CQPweb)
java·前端·vue.js