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);
}
相关推荐
超梦dasgg3 分钟前
Dijkstra(迪杰斯特拉)算法详解
java·数据结构·算法
MacroZheng4 分钟前
给Claude Code装上这个超酷的状态栏,瞬间高大上了!
java·人工智能·后端
有梦想的程序星空7 分钟前
【环境配置】IDEA+Scala 项目 JAR 打包异常完整排查指南
java·ide·intellij-idea
小程故事多_8013 分钟前
从初代架构到大模型时代,英伟达GPU底层架构演进与核心逻辑深度解析
java·人工智能·分布式·架构
组合缺一17 分钟前
Solon 热加载与插件热插拔:Debug 模式 × E-Spi × H-Spi 全解析
java·solon·插件·plugin·热插拨
MageGojo17 分钟前
Whois 域名查询 API 接入实战:用一个 GET 请求获取域名注册信息
java·git·github
MandalaO_O18 分钟前
SpringMVC:框架搭建、核心配置与前后端交
java
jerryinwuhan19 分钟前
marker BiBERTo解释
java·前端·人工智能
在繁华处27 分钟前
Java从零到熟练(八):泛型与注解
java·开发语言·python
半夜修仙36 分钟前
RabbitMQ入门概述
java·rabbitmq·java-rabbitmq