Spring Boot 参数校验机制原理以及如何实现一个自定义校验注解

Spring Boot 参数校验原理

Spring Boot 提供了一种方便的参数校验机制,借助于 JSR-303(Bean Validation)规范,通过在方法参数上添加校验注解来实现参数校验。下面是 Spring Boot 参数校验的基本原理:

  1. JSR-303 标准注解: Spring Boot 使用了 JSR-303 提供的一系列标准注解来进行参数校验,如 @NotNull@Size@Min@Max@Email 等。

  2. Hibernate Validator: Spring Boot 默认使用 Hibernate Validator 作为其 Bean Validation 实现。Hibernate Validator 是对 Bean Validation 规范的一个实现,它支持 JSR-303 定义的所有校验注解,并且提供了一些扩展注解。

  3. 方法参数上的校验注解: 在 Spring Boot 的控制器方法中,可以在方法参数上添加校验注解,如 @Valid@NotNull@Size 等。当请求到达控制器方法时,Spring Boot 会根据这些注解自动对参数进行校验。

  4. 参数校验的触发时机: 参数校验是在 Spring MVC 的请求处理流程中触发的,在参数绑定到控制器方法的过程中进行校验。当请求到达控制器方法时,Spring Boot 会自动根据方法参数上的校验注解执行校验逻辑。

  5. 校验结果处理: 如果参数校验失败,Spring Boot 会抛出 MethodArgumentNotValidException 异常,并返回相应的错误信息给客户端。开发者可以通过异常处理器或者全局异常处理机制来自定义校验失败时的处理逻辑。

  6. 全局校验器配置: Spring Boot 允许开发者通过配置 Validator 或者 LocalValidatorFactoryBean 来自定义全局的校验器,从而实现一些更加复杂的校验逻辑或者自定义的校验器。

总的来说,Spring Boot 的参数校验机制基于 JSR-303 标准注解和 Hibernate Validator 实现,通过在方法参数上添加校验注解来实现对参数的校验,从而保证了系统接口的数据完整性和安全性。

如何实现自定义校验注解

要创建一个自定义的校验注解,你需要遵循以下步骤:

  1. 创建注解类:首先,创建一个注解类,用于定义你的自定义校验注解的名称和属性。

  2. 编写校验逻辑:编写一个校验器,用于实际执行校验逻辑。

  3. 关联注解和校验器:将自定义的注解与校验器关联起来,以便在使用注解时触发校验器。

下面是一个简单的示例,演示如何创建一个自定义的校验注解来验证 JSON 字符串:

import javax.validation.Constraint;
import javax.validation.Payload;
import java.lang.annotation.*;@Target({ElementType.FIELD, ElementType.PARAMETER})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Constraint(validatedBy = JsonStringValidator.class) // 指定校验器
public @interface ValidJsonString {String message() default "Invalid JSON String"; // 默认错误信息Class<?>[] groups() default {};Class<? extends Payload>[] payload() default {};
}

在上面的示例中,@ValidJsonString 是自定义的校验注解,它关联了一个校验器 JsonStringValidator

接下来,我们需要编写校验器 JsonStringValidator

import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;public class JsonStringValidator implements ConstraintValidator<ValidJsonString, String> {@Overridepublic void initialize(ValidJsonString constraintAnnotation) {// 初始化方法}@Overridepublic boolean isValid(String jsonString, ConstraintValidatorContext context) {if (jsonString == null) {return false;}try {// 在这里编写你的校验逻辑,例如使用 JSON 解析器来解析 JSON 字符串,判断是否合法// 这里只是一个简单示例,你可以根据实际需求进行更复杂的校验逻辑// 这里简单地检查字符串是否可以被 JSON 解析器成功解析ObjectMapper objectMapper = new ObjectMapper();objectMapper.readTree(jsonString);return true;} catch (IOException e) {return false;}}
}

在上面的示例中,JsonStringValidator 类实现了 ConstraintValidator<ValidJsonString, String> 接口,并重写了 isValid 方法,在该方法中执行了 JSON 字符串的校验逻辑。

现在,你就可以在你的 Java Bean 中使用 @ValidJsonString 注解来校验 JSON 字符串了:

public class MyBean {@ValidJsonStringprivate String jsonString;// 其他代码
}

当你在 Spring Boot 控制器或者服务中使用这个 Bean 时,Spring Boot 会自动执行 @ValidJsonString 注解定义的校验逻辑。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/700600.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

展锐S8000安卓核心板参数_紫光展锐5G核心板模块定制方案

展锐S8000核心板模块是基于八核S8000平台开发设计的&#xff0c;采用了先进的6nm EUV制程技术。搭载了全新的智能Android 13操作系统&#xff0c;展现出超强的画面解析能力和高性能双通道MIPI&#xff0c;拥有120Hz高刷新率&#xff0c;独立NPU和3.2TOPS Al算力&#xff0c;同时…

自旋锁Led驱动程序的测试

一. 简介 前面一篇文章对自旋锁的使用方法进行了代码实现,文章地址如下: Linux内核自旋锁驱动代码实现-CSDN博客 本文对所实现的自旋锁的Led驱动程序进行测试,确定自旋锁是否实现对 Led设备的互斥访问。 二. 自旋锁Led驱动代码的测试 前面对添加自旋锁的Led驱动代码进…

【机器学习】特征工程之特征选择

&#x1f388;个人主页&#xff1a;豌豆射手^ &#x1f389;欢迎 &#x1f44d;点赞✍评论⭐收藏 &#x1f917;收录专栏&#xff1a;机器学习 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共同学习、交流进…

C# RabbitMQ使用--动态更新

在使用 RabbitMQ 的 C# 客户端库时&#xff0c;只需要在应用程序中引用 RabbitMQ.Client 包&#xff0c;而不需要单独安装 RabbitMQ 服务器。 RabbitMQ.Client 是一个用于在 C# 中与 RabbitMQ 服务器进行通信的客户端库。通过使用该客户端库&#xff0c;你可以在应用程序中创建…

数字化转型导师坚鹏:政府数字化流程管理

政府数字化流程管理 课程背景&#xff1a; 很多政府存在以下问题&#xff1a; 不清楚数字化对流程有什么影响&#xff1f; 不知道政府业流程如何进行优化&#xff1f; 不知道政府业流程优化的具体案例&#xff1f; 课程特色&#xff1a; 有实战案例 有原创观点 …

盲目的追求完美主义可能会导致一事无成,在平时的工作中,我们应该追求全局最优,而不是局部最优。

经验分享&#xff1a; 盲目的追求完美主义可能会导致一事无成&#xff0c;在平时的工作中&#xff0c;我们应该追求全局最优&#xff0c;而不是局部最优。我们在做一件事情&#xff0c;先保证拿到60分&#xff0c;然后先去追求其他事情&#xff0c;等其他事情也能拿到60分&…

【README 小技巧】在项目README.md 中展示发布到maven 仓库版本

在项目README.md 中展示发不到nexus 的快照版本 <p align"center"><a target"_blank" href"https://search.maven.org/search?qwu-lazy-cloud-network%20wu-lazy-cloud-network"><img src"https://img-home.csdnimg.cn/ima…

代码随想录算法训练营第四十一天|416.分割等和子集

416.分割等和子集 public class Solution {public bool CanPartition(int[] nums) {int[] dpnew int[10001];int sum0;for(int i0;i<nums.Length;i){sumnums[i];}if(sum%21){return false;}int targetsum/2;for(int i0;i<nums.Length;i){for(int jtarget;j>nums[i];…

【最新Dubbo3深入理解】Dubbo3源码中的一些小技巧

欢迎关注公众号&#xff08;通过文章导读关注&#xff1a;【11来了】&#xff09;&#xff0c;及时收到 AI 前沿项目工具及新技术的推送&#xff01; 在我后台回复 「资料」 可领取编程高频电子书&#xff01; 在我后台回复「面试」可领取硬核面试笔记&#xff01; 文章导读地址…

“点击查看显示全文”遇到的超链接默认访问的问题

今天在做一个例子&#xff0c;就是很常见的点击展开全文。 我觉得这是一个很简单的效果&#xff0c;也就几行代码的事&#xff0c;结果点击了以后立刻隐藏不见&#xff0c;控制台代码也不报错&#xff0c;耽误了我很长时间&#xff0c;最后才发现问题出在超链接身上。 “展开全…

太阳能光伏电池模型参数辨识模型介绍

一、太阳能光伏电池模型参数辨识模型介绍 由于传统化石能源短缺问题日益严重&#xff0c;我国对新能源发展的重视提到了前所未有的高度。太阳能作为一种可再生能源&#xff0c;不会对环境造成污染&#xff0c;受到了越来越多的关注太阳能由于其储量丰富,无污染和无地域限制等优…

Clickhouse系列之连接工具连接、数据类型和数据库

基本操作 一、使用连接工具连接二、数据类型1、数字类型IntFloatDecimal 2、字符串类型StringFixedStringUUID 3、时间类型DateTimeDateTime64Date 4、复合类型ArrayEnum 5、特殊类型Nullable 三、数据库 一、使用连接工具连接 上一篇介绍了clickhouse的命令行登录&#xff0c…

【大厂AI课学习笔记NO.52】2.3深度学习开发任务实例(5)需求采集考虑维度

今天来学习&#xff0c;怎么做需求分析&#xff0c;如何明确数据采集需求。 我把自己考试通过的学习笔记&#xff0c;都分享到这里了&#xff0c;另外还有一个比较全的思维脑图&#xff0c;我导出为JPG文件了。下载地址在这里&#xff1a;https://download.csdn.net/download/g…

软件设计师软考题目解析02 --每日五题

想说的话&#xff1a;要准备软考了。0.0&#xff0c;其实我是不想考的&#xff0c;但是吧&#xff0c;由于本人已经学完所有知识了&#xff0c;只是被学校的课程给锁在那里了&#xff0c;不然早找工作去了。寻思着反正也无聊&#xff0c;就考个证玩玩。 本人github地址&#xf…

C++之std::async

std::async是C提供的一个异步处理函数。 函数原型&#xff1a; template<typename _Fn, typename... _Args> future<__async_result_of<_Fn, _Args...>> async(launch __policy, _Fn&& __fn, _Args&&... __args); 参数说明: int thFun(in…

MT8791迅鲲900T联发科5G安卓核心板规格参数_MTK平台方案定制

MT8791安卓核心板是一款搭载了旗舰级配置的中端手机芯片。该核心板采用了八核CPU架构设计&#xff0c;但是升级了旗舰级的Arm Cortex-A78核心&#xff0c;两个大核主频最高可达2.4GHz。配备了Arm Mali-G68 GPU&#xff0c;通过Mali-G88的先进技术&#xff0c;图形处理性能大幅提…

xtu oj 1233 Cycle Matrix 2.0

题目描述 给定N&#xff0c;输出一个N*N的矩阵&#xff0c;矩阵为N层&#xff0c;每层是一个字符&#xff0c;从A到Z。 比如说N3,矩阵为 CCCCC CBBBC CBABC CBBBC CCCCC输入 第一行是一个整数K&#xff08;K≤50&#xff09;,表示样例数。 每个样例占1行&#xff0c;为一个整…

更新从MySQL中读取数据时发现MySQL中的时间字段会相差8小时?

这里写自定义目录标题 修改事件A中的某些字段的数据&#xff0c;规则表中事件A对应的规则字段不发生改变 业务需求&#xff1a;需要将MySQL中的两张表同步到ES中&#xff08;新增、修改、删除同步&#xff09;&#xff0c;优化事件查询速度 解决方案&#xff1a;使用logstash-i…

对实现移动应用界面设计的思考

1. 屏幕 1.1. 屏幕的职责 现在的移动设备都使用触摸屏&#xff0c;触摸屏承担了两项职责&#xff1a;展示界面和处理用户操作指令。界面上展示的东西又可以分为内容和样式。比如展示一行大标题&#xff0c;标题文字是内容&#xff0c;字体、字号、颜色、背景色等等是样式。处…

Python 实现 ATR 指标计算(真实波幅):股票技术分析的利器系列(10)

Python 实现 ATR 指标计算&#xff08;真实波幅&#xff09;&#xff1a;股票技术分析的利器系列&#xff08;10&#xff09; 介绍算法解释 代码rolling函数介绍核心代码 完整代码 介绍 ATR&#xff08;真实波幅&#xff09;是一种技术指标&#xff0c;用于衡量市场波动性的程…