SpringBoot 使用validation数据校验之分组校验怎么玩?·分组还有这么多讲究 - 第408篇

本文主要是介绍SpringBoot 使用validation数据校验之分组校验怎么玩?·分组还有这么多讲究 - 第408篇,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

关历史文章(阅读本文前,您可能需要先看下之前的系列👇

国内最全的Spring Boot系列之四

享元模式:共享女友 - 第355篇

Spring Boot条件注解 - 第400篇

SpringBoot自定义Condition注解实战 - 第402篇

Spring Boot @ConditionalOnClass上的注解你了解多少-java元注解和注解 - 第404篇

SpringBoot 使用validation数据校验-超级详细超级多干货 - 第406篇

悟纤:师傅,脑瓜疼?

师傅:徒儿,何事让你如此“躁动不安”?

悟纤:这个validation虽然好用,但是要是碰到了不同的接口,需要对于不同的参数进行校验呢?

师傅:徒儿,你这话有点绕,可否举例说明下。

悟纤:师傅,你看哦,我有个接口是需要校验username和passsword参数的,但不需要校验email参数;另外一个接口是需要校验email参数的。

悟纤:师傅,你看这种需求何解。

师傅:此时此刻,我想吟诗一首。

师傅:徒儿有难,师傅来相救。不同接口不同校验,分组校验来相助。

​悟纤:师傅这是说,校验可以分组?

师傅:徒儿,理解的对。

悟纤:漂亮的美女一起来研究研究分组校验如何搞?

       分组校验:我们可以把校验注解配置group属性,从而通过分组来满足不同场景下的需求。

       我们还是直接看些例子来有一个更加直观的感受。

       Spring Boot validation系列:

(1)✅《SpringBoot 使用validation数据校验-超级详细超级多干货》

(2)✅《SpringBoot 使用validation数据校验之分组校验怎么玩?·分组还有这么多的讲究》

(3)《SpringBoot 使用validation数据校验之自定义校验注解·源码分析+实例》

(4)《SpringBoot 使用validation数据校验之国际化问题怎么搞?》满满的干货

       这一节我们先来看看《SpringBoot 使用validation数据校验之分组校验怎么玩?》。

一、增删改场景

1.1场景描述

       在实际开发中经常会遇到这种情况:添加用户时,id是由后端生成的,不需要校验id是否为空,但是修改用户时就需要校验id是否为空。如果在接收参数的User实体类的id属性上添加NotNull,显然无法实现。这时候就可以定义分组,在需要校验id的时候校验,不需要的时候不校验。

1.2 定义分组

       定义分组,接口就行:

import javax.validation.GroupSequence;/** * 分组校验 - 定义分组 * * @author 悟纤「公众号SpringBoot」 * @date 2021-10-14 * @slogan 大道至简 悟在天成 */public class ValidGroup {    // 新增使用(配合spring的@Validated功能分组使用)    public interface Insert{}    // 更新使用(配合spring的@Validated功能分组使用)    public interface Update{}    // 删除使用(配合spring的@Validated功能分组使用)    public interface Delete{}    // 属性必须有这两个分组的才验证(配合spring的@Validated功能分组使用)    @GroupSequence({Insert.class, Update.class,Delete.class})    public interface All{}}

1.3在实体类的注解中标记id使用上面定义的组

       在每个注解中有一个属性groups,添加此属性就行:

//只能在Delete和Update的时候才能够进行生效.@Min(value = 1,message = "ID不能小于1",groups = {ValidGroup.Delete.class,ValidGroup.Update.class})private int id;@NotBlank(message = "用户名不能为空",groups = {ValidGroup.Update.class,ValidGroup.Insert.class})private String username;@NotBlank(message = "密码不能为空",groups = {ValidGroup.Update.class,ValidGroup.Insert.class})@Length(min = 6,max = 20,message = "密码长度在6-20之间")private String password;@NotBlank(message = "邮箱不能为空")@Email(message = "邮箱格式不合理")private String email;

1.4在controller中使用@Validated指定使用哪个组

在controller中使用@Validated指定使用哪个组:

@RequestMapping("/saveUserInfo")public UserInfo saveUserInfo(@Validated() UserInfo userInfo){    //save userInfo:将userInfo进行保存    //userInfoService.save(userInfo);    return userInfo;}@RequestMapping("/updateUserInfo")public UserInfo updateUserInfo(@Validated({ValidGroup.Update.class}) UserInfo userInfo){    //save userInfo:将userInfo进行保存    //userInfoService.update(userInfo);    return userInfo;}@RequestMapping("/deleteUserInfo")public UserInfo deleteUserInfo(@Validated({ValidGroup.Delete.class}) UserInfo userInfo){    //save userInfo:将userInfo进行保存    //userInfoService.delete(userInfo);    return userInfo;}

1.5 测试

保存数据:

http://127.0.0.1:8080/userInfo/saveUserInfo?username=wuqian&password=1234456&email=aa@qq.com

说明:保存的方法上并没有指定具体的分组,所以生效的配置只有email,所以在保存的时候以下的链接就能保存成功了。

http://127.0.0.1:8080/userInfo/saveUserInfo?email=aa@qq.com

       这里是举例了个错误的例子,大家自行进行修改哦。

修改数据:

http://127.0.0.1:8080/userInfo/updateUserInfo?username=wuqian&password=1234456&id=1

说明:这里的核心是id必须配置,由于email没有在分组内,所以根本不会进行生效。

删除数据:

http://127.0.0.1:8080/userInfo/deleteUserInfo?id=1

说明:删除只需要id。

二、同一个字段不同分组

1.1场景描述

场景:对同一个对象例如User(nickname) 在不同的接口时 需要的校验规则不同。例如,访问一个接口需要 nickname不为空;访问另一个接口 需要 nickname参数的长度在 [1,3]之间。

1.2 定义分组

       这里直接使用上面例子中的ValidGroup

1.3在实体类的注解中使用上面定义的组

@NotBlank(message = "昵称不为空")@Size(message = "昵称长度 [1-3] ", min = 1, max = 3,groups = ValidGroup.Update.class)private String nickname;

1.4在controller中使用@Validated指定使用哪个组

@RequestMapping("/testNikname1")public UserInfo testNikname1(@Validated() UserInfo userInfo){    //save userInfo:将userInfo进行保存    //userInfoService.update(userInfo);    return userInfo;}@RequestMapping("/testNikname2")public UserInfo testNikname2(@Validated({ValidGroup.Update.class}) UserInfo userInfo){    //save userInfo:将userInfo进行保存    //userInfoService.update(userInfo);    return userInfo;}

1.5 测试

       访问:/userInfo/testNikname1

       如果没有设置参数nickname是会报错的:defaultmessage [昵称不为空]]

       如果带了参数nickname,

/userInfo/testNikname1?nickname=good,那么@Size校验是不会生效的,因为设置了分组了。

       访问:/userInfo/testNikname,不设置参数nickname的时候是不会报错的,如果设置了参数nickname,那么就要满足@Size定义的规则了。

       当然上面的编码方式,并没有明确指定@NotBlank的分组,你也是可以进行指定的:

@NotBlank(message = "昵称不为空",groups = ValidGroup.Insert.class)@Size(message = "昵称长度 [1-3] ", min = 1, max = 3,groups = ValidGroup.Update.class)private String nickname;

       这就实现了同一个字段,不同分组不同校验规则。

我就是我,是颜色不一样的烟火。
我就是我,是与众不同的小苹果。

à云课堂学院:悟空学院

学院中有Spring Boot相关的课程!!

SpringBoot视频:从零开始学Spring Boot Plus - 网易云课堂

SpringBoot交流平台:https://t.cn/R3QDhU0

SpringSecurity5.0视频:权限管理spring security - 网易云课堂

ShardingJDBC分库分表:分库分表Sharding-JDBC实战 - 网易云课堂

分布式事务解决方案:分布式事务解决方案「手写代码」 - 网易云课堂

JVM内存模型调优实战:深入理解JVM内存模型/调优实战 - 网易云课堂

Spring入门到精通:Spring零基础从入门到精通 - 网易云课堂

大话设计模式之爱你:大话设计模式之爱你一万年 - 网易云课堂

这篇关于SpringBoot 使用validation数据校验之分组校验怎么玩?·分组还有这么多讲究 - 第408篇的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/309559

相关文章

Java Stream流与使用操作指南

《JavaStream流与使用操作指南》Stream不是数据结构,而是一种高级的数据处理工具,允许你以声明式的方式处理数据集合,类似于SQL语句操作数据库,本文给大家介绍JavaStream流与使用... 目录一、什么是stream流二、创建stream流1.单列集合创建stream流2.双列集合创建str

springboot集成easypoi导出word换行处理过程

《springboot集成easypoi导出word换行处理过程》SpringBoot集成Easypoi导出Word时,换行符n失效显示为空格,解决方法包括生成段落或替换模板中n为回车,同时需确... 目录项目场景问题描述解决方案第一种:生成段落的方式第二种:替换模板的情况,换行符替换成回车总结项目场景s

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很