Spring WebFlux使用未加前缀的双通配符模式绕过安全性CVE-2023-34034

本文主要是介绍Spring WebFlux使用未加前缀的双通配符模式绕过安全性CVE-2023-34034,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 0.前言
    • 漏洞
    • 漏洞介绍
    • 描述
  • 1.参考文档
  • 2.基础介绍
  • 3.解决方案
    • 3.1. 升级版本
  • 4.漏洞修复源码分析
  • 5. 漏洞利用示例

在这里插入图片描述

0.前言

背景:公司项目扫描到 WebFlux中使用"**"作为模式会导致Spring Security和Spring WebFlux之间 CVE-2023-34034漏洞

漏洞

高 | 2023年7月18日 | CVE-2023-34034

在Spring Security配置的WebFlux中使用"**"作为模式会导致Spring Security和Spring WebFlux之间的模式匹配不匹配,从而可能导致安全性绕过。。

漏洞介绍

CVE-2023-34034:WebFlux使用未加前缀的双通配符模式绕过安全性

描述

在Spring Security配置的WebFlux中使用"**"作为模式会导致Spring Security和Spring WebFlux之间的模式匹配不匹配,从而可能导致安全性绕过。

受影响的Spring产品和版本
Spring Security:
6.1.0至6.1.1
6.0.0至6.0.4
5.8.0至5.8.4
5.7.0至5.7.9
5.6.0至5.6.11

以下Spring Security版本修复了此漏洞:

6.1.2+
6.0.5+
5.8.5+
5.7.10+
5.6.12+ 上述版本要求使用以下Spring Framework版本:

6.0.11+
5.3.29+
5.2.25+

1.参考文档

  1. CVE 官方网站 https://www.cve.org/CVERecord
    在这里插入图片描述

  2. https://nvd.nist.gov/vuln-metrics/cvss/v3-calculator?vector=AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:N/E:P/RL:O/RC:C/CR:H/IR:H/AR:X/MAV:N/MAC:L/MPR:N/MUI:N/MS:U/MC:H/MI:H/MA:N&version=3.1

  3. https://security.netapp.com/advisory/ntap-20230814-0008/

2.基础介绍

Spring Security最近发布的新版本修复了一个名为CVE-2023-34034的访问控制漏洞。该漏洞被评为高危漏洞,可能对使用Spring Security进行身份验证和访问控制的Spring WebFlux应用程序造成严重影响。

Spring Security是一个广泛使用的Java身份验证和访问控制框架,用于保护企业级Java应用程序。它与Spring Framework集成,并提供了强大的身份验证和授权功能。

Spring WebFlux是Spring Framework 5引入的一种反应式编程替代方案,用于构建异步、非阻塞和响应式的应用程序。它利用反应式流API来处理请求,具有高性能和可伸缩性的特点。

该漏洞的具体细节是在Spring Security的PathPatternParserServerWebExchangeMatcher类中发现的。在修复之前,该类使用了PathPatternParser类的parse()方法来解析路径模式。修复提交引入了一个新的parse()函数,该函数在解析模式之前会确保模式以斜杠开头。然而,在修复之前,如果模式没有以斜杠结尾并且请求路径包含斜杠,将会绕过路径匹配器,导致身份验证和授权绕过

攻击者可以利用该漏洞通过修改请求路径中的双斜杠来绕过访问控制,从而未经授权地访问受保护的资源。

为了修复该漏洞,建议尽快升级到修复了漏洞的Spring Security版本。同时,需要审查应用程序中的访问控制规则和路径模式,确保它们不会受到此漏洞的影响。特别注意使用PathPatternParserServerWebExchangeMatcher类的地方,并确保路径模式以斜杠结尾。此外,进行安全测试和代码审查是保证应用程序安全性的重要步骤。

及时更新和修复应用程序中的安全漏洞是保护应用程序和用户数据安全的关键措施之一。

3.解决方案

3.1. 升级版本

以下Spring Security版本修复了此漏洞:

6.1.2+
6.0.5+
5.8.5+
5.7.10+
5.6.12+

上述版本要求使用以下Spring Framework版本:

6.0.11+
5.3.29+
5.2.25+

4.漏洞修复源码分析

以下是我们对源代码的深入分析,从修复提交(7813a9b)开始。

web/src/main/java/org/springframework/security/web/server/util/matcher/PathPatternParserServerWebExchangeMatcher.java
在这里插入图片描述

PathPatternParser源代码

在查看对比之前,我们可以看到在修复之前,PathPatternParserServerWebExchangeMatcher类使用了PathPatternParser类中实现的parse()方法。

修复提交引入了一个新的parse()函数,由PathPatternParserServerWebExchangeMatcher类自己实现,它扩展了PathPatternParser的parse()方法,并添加了initFullPathPattern()

从源代码中可以看出,这个实用函数在字符串的开头添加了一个斜杠,前提是它还没有存在。

测试用例明确了问题的本质:如果配置的模式不以斜杠结尾,并且请求路径包含斜杠,则匹配将成功。这实际上允许绕过路径匹配器。

/**为匹配完整URL路径而准备给定的模式。
默认情况下,为非空模式添加前导斜杠。
@param pattern 要初始化的模式
@return 更新后的模式
@since 5.2.25
*/
public String initFullPathPattern(String pattern) {
return (StringUtils.hasLength(pattern) && !pattern.startsWith("/") ? "/" + pattern : pattern);
}// 进一步查看提交时,新引入的测试验证了这一评估:
class PathPatternParserServerWebExchangeMatcherTests {reasonml
Copy
@Test
void matchesWhenConfiguredWithNoTrailingSlashAndPathContainsSlashThenMatches() {PathPatternParserServerWebExchangeMatcher matcher = new PathPatternParserServerWebExchangeMatcher("user/**");MockServerHttpRequest request = MockServerHttpRequest.get("/user/test").build();assertThat(matcher.matches(MockServerWebExchange.from(request)).继续上一条回答:
.build().isMatch()).isTrue();
}reasonml
Copy
@Test
void matchesWhenConfiguredWithNoTrailingSlashAndPathDoesNotContainSlashThenDoesNotMatch() {PathPatternParserServerWebExchangeMatcher matcher = new PathPatternParserServerWebExchangeMatcher("user/**");MockServerHttpRequest request = MockServerHttpRequest.get("/user").build();assertThat(matcher.matches(MockServerWebExchange.from(request)).build().isMatch()).isFalse();
}@Test
void matchesWhenConfiguredWithTrailingSlashAndPathContainsSlashThenMatches() {PathPatternParserServerWebExchangeMatcher matcher = new PathPatternParserServerWebExchangeMatcher("user/**/");MockServerHttpRequest request = MockServerHttpRequest.get("/user/test").build();assertThat(matcher.matches(MockServerWebExchange.from(request)).build().isMatch()).isTrue();
}@Test
void matchesWhenConfiguredWithTrailingSlashAndPathDoesNotContainSlashThenDoesNotMatch() {PathPatternParserServerWebExchangeMatcher matcher = new PathPatternParserServerWebExchangeMatcher("user/**/");MockServerHttpRequest request = MockServerHttpRequest.get("/user").build();assertThat(matcher.matches(MockServerWebExchange.from(request)).build().isMatch()).isFalse();
}
}

5. 漏洞利用示例

为了更好地理解漏洞是如何被利用的,我们可以通过以下示例演示:

假设我们有一个Spring WebFlux应用程序,其中配置了以下路径模式:

PathPatternParserServerWebExchangeMatcher matcher = new PathPatternParserServerWebExchangeMatcher("admin/**");

当用户尝试访问/admin/test路径时,由于该路径与模式匹配,Spring Security将执行身份验证和授权检查。

现在,如果攻击者尝试访问以下路径:

/admin//test
请注意,请求路径中的双斜杠(//)会绕过路径匹配器的检查,导致绕过身份验证和授权检查。攻击者可以在未经授权的情况下访问受保护的资源。

这篇关于Spring WebFlux使用未加前缀的双通配符模式绕过安全性CVE-2023-34034的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/wangshuai6707/article/details/132897594
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/837286

相关文章

Java日期类详解(最新推荐)

《Java日期类详解(最新推荐)》早期版本主要使用java.util.Date、java.util.Calendar等类,Java8及以后引入了新的日期和时间API(JSR310),包含在ja... 目录旧的日期时间API新的日期时间 API(Java 8+)获取时间戳时间计算与其他日期时间类型的转换Dur

java对接海康摄像头的完整步骤记录

《java对接海康摄像头的完整步骤记录》在Java中调用海康威视摄像头通常需要使用海康威视提供的SDK,下面这篇文章主要给大家介绍了关于java对接海康摄像头的完整步骤,文中通过代码介绍的非常详细,需... 目录一、开发环境准备二、实现Java调用设备接口(一)加载动态链接库(二)结构体、接口重定义1.类型

SpringBoot读取ZooKeeper(ZK)属性的方法实现

《SpringBoot读取ZooKeeper(ZK)属性的方法实现》本文主要介绍了SpringBoot读取ZooKeeper(ZK)属性的方法实现,强调使用@ConfigurationProperti... 目录1. 在配置文件中定义 ZK 属性application.propertiesapplicati

Java Multimap实现类与操作的具体示例

《JavaMultimap实现类与操作的具体示例》Multimap出现在Google的Guava库中,它为Java提供了更加灵活的集合操作,:本文主要介绍JavaMultimap实现类与操作的... 目录一、Multimap 概述Multimap 主要特点:二、Multimap 实现类1. ListMult

Java中常见队列举例详解(非线程安全)

《Java中常见队列举例详解(非线程安全)》队列用于模拟队列这种数据结构,队列通常是指先进先出的容器,:本文主要介绍Java中常见队列(非线程安全)的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一.队列定义 二.常见接口 三.常见实现类3.1 ArrayDeque3.1.1 实现原理3.1.2

CnPlugin是PL/SQL Developer工具插件使用教程

《CnPlugin是PL/SQLDeveloper工具插件使用教程》:本文主要介绍CnPlugin是PL/SQLDeveloper工具插件使用教程,具有很好的参考价值,希望对大家有所帮助,如有错... 目录PL/SQL Developer工具插件使用安装拷贝文件配置总结PL/SQL Developer工具插

SpringBoot整合Apache Flink的详细指南

《SpringBoot整合ApacheFlink的详细指南》这篇文章主要为大家详细介绍了SpringBoot整合ApacheFlink的详细过程,涵盖环境准备,依赖配置,代码实现及运行步骤,感兴趣的... 目录1. 背景与目标2. 环境准备2.1 开发工具2.2 技术版本3. 创建 Spring Boot

springboot加载不到nacos配置中心的配置问题处理

《springboot加载不到nacos配置中心的配置问题处理》:本文主要介绍springboot加载不到nacos配置中心的配置问题处理,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录springboot加载不到nacos配置中心的配置两种可能Spring Boot 版本Nacos

SpringBoot3中使用虚拟线程的完整步骤

《SpringBoot3中使用虚拟线程的完整步骤》在SpringBoot3中使用Java21+的虚拟线程(VirtualThreads)可以显著提升I/O密集型应用的并发能力,这篇文章为大家介绍了详细... 目录1. 环境准备2. 配置虚拟线程方式一:全局启用虚拟线程(Tomcat/Jetty)方式二:异步

Java反射实现多属性去重与分组功能

《Java反射实现多属性去重与分组功能》在Java开发中,​​List是一种非常常用的数据结构,通常我们会遇到这样的问题:如何处理​​List​​​中的相同字段?无论是去重还是分组,合理的操作可以提高... 目录一、开发环境与基础组件准备1.环境配置:2. 代码结构说明:二、基础反射工具:BeanUtils