CVE-2022-22978源码分析与漏洞复现

漏洞概述

CVE-2022-22978 是 Spring Security 框架中的一个高危认证绕过漏洞,影响版本包括 Spring Security 5.5.x < 5.5.75.6.x < 5.6.4 及更早的不受支持版本。攻击者可通过构造包含换行符(如 %0a)的 URL 路径,绕过正则表达式匹配规则,导致权限校验失效,实现未授权访问受保护资源。


技术细节分析

1. 漏洞成因
  • 正则表达式匹配模式缺陷
    Spring Security 的 RegexRequestMatcher 在处理 URL 路径匹配时,若正则表达式中包含 . 字符(例如 /admin/.*),默认情况下 . 不会匹配换行符(\n\r)。攻击者可通过在 URL 中插入 URL 编码的换行符(%0a%0d)绕过校验。
  • 安全上下文配置缺失
    漏洞版本的 RegexRequestMatcher 未启用 Pattern.DOTALL 标志,导致正则表达式未覆盖换行符等特殊字符,从而产生逻辑漏洞。
2. 源码分析
关键代码 1:RegexRequestMatcher 构造函数(漏洞版本)
public RegexRequestMatcher(String pattern, String httpMethod, boolean caseInsensitive) {// 漏洞点:未设置 Pattern.DOTALL,导致 . 不匹配换行符this.pattern = Pattern.compile(pattern, caseInsensitive ? CASE_INSENSITIVE : DEFAULT);this.httpMethod = StringUtils.hasText(httpMethod) ? HttpMethod.valueOf(httpMethod) : null;
}

问题点

  • DEFAULT 模式未包含 Pattern.DOTALL,导致 . 无法匹配换行符(如 \n)。
关键代码 2:修复版本代码对比
public final class RegexRequestMatcher implements RequestMatcher {
- private static final int DEFAULT = 0;
+ private static final int DEFAULT = Pattern.DOTALL; // 修复点:默认启用 DOTALL

修复逻辑

  • 强制启用 Pattern.DOTALL,使 . 匹配所有字符(包括换行符)。
关键代码 3:SpringSecurityConfig配置问题
 protected void configure(HttpSecurity httpSecurity) throws Exception {    
((ExpressionUrlAuthorizationConfigurer.AuthorizedUrl)httpSecurity.authorizeRequests().regexMatchers(new String[] { "/admin/.*" })).authenticated();}
  • 使用/admin/.*进行匹配
漏洞触发示例
  • 恶意 URL/admin/111%0a
    • 漏洞版本正则 /admin/.* 不会匹配 %0a(即 \n),导致路径 /admin/111\n 被误判为合法路径,绕过权限校验。

漏洞复现

环境搭建
1.使用 Vulhub 环境启动漏洞靶机:
docker-compose up -d

在这里插入图片描述

2.访问 http://target:8080,确认服务正常运行

在这里插入图片描述

攻击步骤
  1. 正常访问受限接口
    访问 /admin,触发 302 跳转至登录页。
    在这里插入图片描述

  2. 构造绕过请求
    访问 /admin/%0a,成功绕过认证并访问受保护资源。
    在这里插入图片描述


修复方案

  1. 升级版本
    升级至 Spring Security 5.5.7+5.6.4+,修复了 RegexRequestMatcher 的正则匹配逻辑。
  2. 输入过滤
    对 URL 路径进行规范化处理,过滤 %0a%0d 等特殊字符。
  3. 安全配置强化
    避免在正则表达式中过度依赖 .,改用更精确的匹配规则(如 [^/]+)。

总结

CVE-2022-22978 暴露了 Spring Security 在正则表达式匹配模式配置上的安全隐患。其根本原因在于默认未启用 Pattern.DOTALL,导致攻击者可利用换行符绕过权限校验。修复方案通过强制启用 DOTALL 标志,确保正则表达式匹配覆盖所有字符。开发者应避免在权限规则中使用宽松的正则表达式。


参考链接

  1. Spring 官方安全公告
  2. 漏洞修复 Commit 记录
  3. 漏洞复现环境(GitHub)
  4. NVD 漏洞数据库条目
  5. FreeBuf 技术分析

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

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

相关文章

PostGIS实现栅格数据入库【raster2pgsql】

raster2pgsql使用与最佳实践 一、工具概述 raster2pgsql是PostGIS提供的命令行工具,用于将GDAL支持的栅格格式(如GeoTIFF、JPEG、PNG等)导入PostgreSQL数据库,支持批量加载、分块切片、创建空间索引及金字塔概览,是栅格数据入库的核心工具。 二、核心功能与典型用法 1…

Redis企业级开发实战:核心应用场景与最佳实践

引言 Redis&#xff08;Remote Dictionary Server&#xff09;作为一款高性能的内存数据库&#xff0c;在企业级开发中扮演着至关重要的角色。无论是缓存加速、分布式锁、实时统计&#xff0c;还是消息队列&#xff0c;Redis都能以极低的延迟和极高的吞吐量满足业务需求。本文…

深入解析Spring Boot与Spring Cloud在微服务架构中的实践

深入解析Spring Boot与Spring Cloud在微服务架构中的实践 引言 随着云计算和分布式系统的快速发展&#xff0c;微服务架构已成为现代软件开发的主流模式。Spring Boot和Spring Cloud作为Java生态中微服务开发的核心框架&#xff0c;为开发者提供了强大的工具和组件&#xff0…

AI量化交易是什么?它是如何重塑金融世界的?

第一章&#xff1a;证券交易的进化之路 1.1 从喊价到代码&#xff1a;交易方式的革命性转变 在电子交易普及之前&#xff0c;证券交易依赖于交易所内的公开喊价系统。交易员通过手势、喊话甚至身体语言传递买卖信息&#xff0c;这种模式虽然直观&#xff0c;但效率低下且容易…

芯驰科技与安波福联合举办技术研讨会,深化智能汽车领域合作交流

5月15日&#xff0c;芯驰科技与全球移动出行技术解决方案供应商安波福&#xff08;Aptiv&#xff09;在上海联合举办以“芯智融合&#xff0c;共赢未来”为主题的技术研讨会。会上&#xff0c;双方聚焦智能座舱与智能车控的发展趋势&#xff0c;展开深入交流与探讨&#xff0c;…

大数据Spark(五十九):Standalone集群部署

文章目录 Standalone集群部署 一、节点划分 二、搭建Standalone集群 1、将下载好的Spark安装包上传解压 2、配饰spark-env.sh 3、配置workers 4、将配置好的安装包发送到node2、node3节点上 5、启动Standalone集群 三、提交任务测试 Standalone集群部署 Standalone 模…

Feign异步模式丢失上下文问题

Feign异步模式丢失上下文问题 问题描述 当我们使用异步对我们代码进行操作优化时&#xff0c;代码中使用了RequestContextHolder去获取上下文的数据&#xff0c;当我们执行原来可以执行的业务时发现报了空指针异常或数据为空&#xff0c;这是为什么呢&#xff1f; 原理解释 …

JavaScript作用域和作用域链

在JavaScript中&#xff0c;作用域和作用域链是理解代码执行和变量访问的关键概念。它们决定了变量和函数在代码中的可见性和生命周期。 一、作用域&#xff08;Scope&#xff09; &#xff08;一&#xff09;什么是作用域&#xff1f; 作用域是在运行时代码中的某些特定部分…

人工智能的“歧视”:“她数据”在算法运行中隐形

纵观人类的发展史&#xff0c;每一次科技进步都将对性别平等产生深刻影响。尤其是当下&#xff0c;人们对于借助人工智能技术快速发展来弥合性别不平等寄予厚望。 但很多人没想过&#xff0c;人工智能技术本身是客观中立、不存在“算法歧视”“性别偏见的吗&#xff1f; 弗吉…

设备全生命周期管理:从采购到报废的数字化闭环方案

在当今数字化时代&#xff0c;企业对设备的管理已不再局限于简单的维护与修理&#xff0c;而是追求从采购到报废的全生命周期数字化闭环管理。易点易动设备管理系统&#xff0c;正是这一趋势下的佼佼者&#xff0c;它为企业提供了一套高效便捷的设备管理解决方案。 采购阶段&a…

React中useState中更新是同步的还是异步的?

文章目录 前言一、useState 的基本用法二、useState 的更新机制1. 内部状态管理2. 状态初始化3. 状态更新 三、useState 的更新频率与异步行为1. 异步更新与批量更新2. 为什么需要异步更新&#xff1f; 四、如何正确处理 useState 的更新1. 使用回调函数形式的更新2. 理解异步更…

FEKO许可证与其他电磁仿真软件的比较

在电磁仿真领域&#xff0c;众多软件工具竞相争艳&#xff0c;而FEKO软件及其许可证制度在其中独树一帜。本文将对比FEKO许可证与其他电磁仿真软件&#xff0c;突出FEKO在许可证方面的卓越性能与独特优势&#xff0c;帮助您做出明智的选择。 一、许可证成本与价值比较 相较于其…

绿色云计算:数字化转型与可持续发展的完美融合

目录 引言 绿色云计算的概念与定义 云计算的环境影响与绿色云计算的重要性 绿色云计算的技术实践与策略 绿色云计算的案例研究与最佳实践 绿色云计算的挑战与限制 绿色云计算的未来趋势与预测 结论与展望 引言 随着云计算技术的迅猛发展和广泛应用&#xff0c;其环境影…

在innovus中如何设置让信号线打上双孔

知识星球【芯冰乐】入口 为了让设计的芯片良率能得到显著提升,一般在绕线资源允许的情况下,我们会在尽可能多的signal线上打上双孔,然而在进行某个项目的时候,小编惊讶的发现,在数字的layout上一个双孔都没出现,这是为什么呢?今天就让小编分享一下这次新奇的发现; 经…

DevExpress GridControl 复选列实时获取选中状态的解决方案

问题核心分析 用户在使用 DevExpress GridControl 的复选列时遇到两个关键问题&#xff1a; 1.使用 CellValueChanged 事件需要点击其他列才会触发&#xff0c;无法实时响应勾选动作 2.使用 CheckedChanged 事件并调用 PostEditor() 会导致复选框无法选中 这主要是因为 DevExp…

数据一致性校验算法

数据完整性校验 在 数据录入、通信协议&#xff08;CAN、LIN、Ethernet&#xff09; 和 存储&#xff08;Flash、EEPROM&#xff09; 领域&#xff0c;数据校验&#xff08;Error Checking&#xff09; 是确保 数据完整性和正确性的关键技术 示例&#xff1a;当我们从互联网上…

101个α因子#9

((0 < ts_min(delta(close, 1), 5)) ? delta(close, 1) : ((ts_max(delta(close, 1), 5) < 0) ? delta(close, 1) : (-1 * delta(close, 1))))worldquant brain平台上调整后的语法&#xff1a; ((0 < min(close-ts_delay(close, 1), ts_delay(close, 1)-ts_delay(c…

国产视频转换LT6211UX:HDMI2.0转LVDS/MIPI芯片简介,支持4K60Hz

1. LT6211UX HDMI2.0信号输入 支持HDMI2.0b, HDMI1.4和DVI1.0 支持HDCP2.2和HDCP1.4 数据速率高达6Gbps 自适应接收机均衡 支持4k60Hz 支持的3D格式&#xff1a; 对于HDMI -> LVDS&#xff1a; 直接3D输出 2路2D L/R输出 对于HDMI -> MIPI&#xff1a; 框架包装&#x…

华三(H3C)IRF堆叠心跳的LACP MAD、BFD MAD和ARP MAD差异

华三&#xff08;H3C&#xff09;IRF堆叠心跳的三种MAD&#xff08;多主检测&#xff09;机制——LACP MAD、BFD MAD和ARP MAD在实现原理、组网要求及适用场景上存在显著差异。以下是三者的对比分析&#xff1a; 一、核心区别对比 特性LACP MADBFD MADARP MAD检测原理扩展LAC…

宿州金博学校开展防震演练:夯实安全根基,守护校园平安

5月13日上午9点30分&#xff0c;金博学校原本宁静的校园被一阵急促的警报声打破&#xff0c;一场精心筹备、紧张有序的防震演练正式开启。本次演练意义重大&#xff0c;旨在强化全体师生的防震减灾意识&#xff0c;提高大家在地震突发时的应急反应与自我保护能力。 紧急避险&am…