当前位置: 首页 > news >正文

SpringBoot3.0 分组校验

文章目录

  • 一、Spring Boot 接口参数校验
  • 二、分组校验
      • 1. 定义分组接口:创建接口定义不同校验分组。例如:
      • 2. 在注解中指定分组:在 `@NotNull`、`@NotEmpty` 等校验注解中,使用 `groups` 属性指定所属分组。
      • 3. 在 `Controller` 层应用分组校验:在 `Controller` 方法中使用 `@Validated` 注解,并指定需要应用的校验分组。
  • 三、分组校验优化

一、Spring Boot 接口参数校验

Spring Boot 提供了强大的参数校验机制,能够有效拦截无效数据,提升系统健壮性。本文将介绍如何结合 @NotNull@NotEmpty@Validated(或更标准的 @Valid)注解,在 Spring Boot 中实现优雅的接口参数校验。
核心思想:
在实体类中,使用 @NotNull 标注不可为 null 的字段,@NotEmpty 标注不可为空字符串的字段。在 Controller 层方法参数上添加 @Validated(或 @Valid)注解,Spring Boot 会在方法调用前自动执行参数校验。若校验失败,将抛出 MethodArgumentNotValidException 异常,可通过全局异常处理机制统一处理,向客户端返回友好的错误信息。
示例代码:

public class User {@NotNullprivate Integer id;@NotEmptyprivate String username;@NotEmptyprivate String password;
}

注意事项

@Validated vs @Valid@Validated 是 Spring 提供的注解
全局异常处理: 建议实现全局异常处理机制,统一处理 MethodArgumentNotValidException异常,并向客户端返回校验错误信息
多请求共用实体类: 使用同一实体类处理多个请求时可能产生冲突。如需更复杂的参数校验逻辑,需使用参数校验分组

二、分组校验

Spring Boot 基于 JSR-303 Bean Validation 规范,通过分组校验机制,可优雅处理同一实体类在不同请求中的差异化校验需求。这避免了为每个请求场景创建不同实体类,提高了代码的可重用性和可维护性。
核心思想:
分组校验允许为同一实体类的不同字段指定差异化校验规则。通过在注解中指定分组,Spring Boot 仅对指定分组内的字段进行校验。这样,即使同一实体类被多个请求使用,也可根据具体场景选择不同的校验规则,避免冲突。
使用方法:
Spring Boot 的 Bean Validation 提供了分组校验功能,通过在 @NotNull@NotEmpty 等校验注解中使用 groups 属性,可控制不同校验规则在不同场景下的应用。这使得同一实体类可在不同请求或业务逻辑中,根据需要进行差异化字段校验,避免冗余代码和校验冲突。
使用步骤:

1. 定义分组接口:创建接口定义不同校验分组。例如:

public interface CreateGroup {}
public interface UpdateGroup {}

2. 在注解中指定分组:在 @NotNull@NotEmpty 等校验注解中,使用 groups 属性指定所属分组。

public class User {@NotNull(groups = CreateGroup.class)private Integer id;@NotEmpty(groups = {CreateGroup.class, UpdateGroup.class})private String username;@NotEmpty(groups = {CreateGroup.class, UpdateGroup.class})private String password;
}

在此示例中,usernamepassword 字段在 CreateGroupUpdateGroup 分组中进行非空校验,id 字段仅在 UpdateGroup 分组中进行邮箱格式校验。

3. 在 Controller 层应用分组校验:在 Controller 方法中使用 @Validated 注解,并指定需要应用的校验分组。


@PostMapping("/user")
public ResponseEntity createUser(@Validated({CreateGroup.class, UpdateGroup.class}) @RequestBody User user) {// ...
}@PutMapping("/user/{id}")
public ResponseEntity updateUser(@Validated({UpdateGroup.class}) @RequestBody User user) {// ...
}

@Validated({CreateGroup.class}) 表示仅对 CreateGroup 分组中的校验规则进行校验。
优势:

代码复用: 同一实体类可被多个请求方法复用,无需为不同校验规则创建多个实体类
可维护性: 校验规则清晰,易于维护和修改
灵活性: 可根据不同业务场景灵活组合校验规则

总结:
通过 groups 属性,可精细控制 Bean Validation 的校验行为,实现更灵活、更强大的数据校验功能,提升代码可读性和可维护性。合理利用分组校验,可有效避免校验冲突,增强系统健壮性。

三、分组校验优化

在 Spring Boot 的 Bean Validation 中,可通过继承Default分组创建新分组,实现更细粒度的校验控制。这在处理新增和更新等不同操作时尤为有用,因为这些操作对数据的校验要求可能不同。
通过继承Default,新分组将包含Default分组中定义的所有校验规则,并可在此基础上添加新规则或覆盖原有规则。这避免了重复定义通用校验规则,提高了代码的可重用性和可维护性。
示例:
假设有AddUpdate两个接口,分别继承自 Default 分组:


public interface Add extends Default {}
public interface Update extends Default {}

User 实体类:


public class User {@NotNull(groups = CreateGroup.class)private Integer id;@NotEmptyprivate String username;@NotEmptyprivate String password;
}

优势

代码复用: Add 和 Update 分组继承 Default 分组,避免重复定义通用校验规则
可维护性: 校验规则清晰,易于维护和修改
灵活性: 可根据不同操作类型灵活定义校验规则

总结
通过继承 Default 分组创建新分组,并结合 @Validated 注解,可有效管理和复用校验规则,构建更健壮、更易维护的 Spring Boot 应用。此方法特别适用于处理新增和更新等具有不同校验需求的操作。需注意,仅在需要添加或修改特定校验规则时才创建新分组,避免过度使用分组导致代码复杂化。

注意:
如有错误请告知
如有侵权请带着截图发邮件
邮箱 1413229255@qq.com

相关文章:

  • Docker Compose 完全指南:从入门到生产实践
  • 打造高效AI批量邮件发送系统
  • C++:类和对象4
  • 【Java学习笔记】属性重写问题
  • matlab中的积分函数
  • 12、电子电路设计与PCB布局组件 (概念) - /设计与仿真组件/pcb-layout-tool
  • 从数据处理到模型训练:深度解析 Python 中的数据结构与操作实践
  • Java volatile关键字深度解析与源码实现
  • 基于大核感知与非膨胀卷积的SPPF改进—融合UniRepLK的YOLOv8目标检测创新架构
  • 苍穹外卖(数据统计–Excel报表)
  • 系统架构设计(四):架构风格总结
  • 基于Python的网络电子书阅读系统
  • ubuntu22.04在 Docker容器中安装 ROS2-Humble
  • Nipype 简单使用教程
  • 锁相放大技术:从噪声中提取微弱信号的利器
  • UE5定序器中摇臂挂载摄像机 让摄像机始终朝向目标
  • 拍电影为什么常用绿幕?认识色度键控(Chroma Key)技术
  • 思维链框架:LLMChain,OpenAI,PromptTemplate
  • [Java实战]Spring Boot 快速配置 HTTPS 并实现 HTTP 自动跳转(八)
  • 【前端】【css】【总复习】三万字详解CSS 知识体系
  • 外企聊营商|波音速度:创新审批促“起飞”
  • 生态环境保护督察工作条例对督察对象和内容作了哪些规定?有关负责人答问
  • 季子文化与江南文化的根脉探寻与融合
  • 金俊峰已跨区任上海金山区委副书记
  • IPO周报|本周A股暂无新股网上申购,年内最低价股周二上市
  • 第19届威尼斯建筑双年展开幕,中国案例呈现“容·智慧”