Spring Security身份认证绕过漏洞(CVE-2022-22978或CVE-2023-34034)复现

Spring Security身份认证绕过漏洞(CVE-2022-22978或CVE-2023-34034)复现

1 漏洞概述

Spring Security是一个基于框架的安全性身份验证和授权管理组件,提供一套完善的安全解决方案,可以轻松地实现基于角色或者资源的安全访问控制以及单点登录等。具有兼容性好、易集成等特点。近日,新华三盾山实验室监测到Spring官方发布了安全公告,修复了一个存在于Spring Security中的身份认证绕过漏洞(CVE-2023-34034),攻击者利用该漏洞可绕过身份认证。

由于Spring Security存在身份认证绕过漏洞,当WebFlux中的Spring Security配置使用“**”作为匹配模式时,会导致Spring Security 和Spring WebFlux之间的模式匹配存在差异,恶意攻击者成功利用此漏洞可绕过身份认证机制。

2 影响范围

Spring Security 6.1.0 <= 6.1.1

Spring Security 6.0.0 <= 6.0.4

Spring Security 5.8.0 <= 5.8.4

Spring Security 5.7.0 <= 5.7.9

Spring Security 5.6.0 <= 5.6.11

修复方案:

目前官方已发布安全更新,请及时升级至最新版本:

Spring Security 5.7.10 >= 5.7.13(仅限企业支持)

Spring Security 5.8.5 >= 5.8.15(仅限企业支持)

Spring Security 6.2.* >= 6.2.7

Spring Security 6.3.* >= 6.3.4

3 严重等级

威胁等级严重
影响程度广泛
利用价值
利用难度中等
漏洞评分9.1

4 poc环境验证

下载地址,5.6.3在范围之内

https://github.com/vulhub/vulhub/tree/master/base/spring/spring-security/5.6.3/code

配置maven,jdk1.8,进行启动

在这里插入图片描述

进行控制层,访问127.0.0.1:8080/admin

@Controller
public class DemoController {
    @GetMapping("/admin/*")
    public String Admin(){
        return "admin";
    }

    @GetMapping("/")
    public String User(){
        return "index";
    }
}

进行访问127.0.0.1:8080/admin,显示成功拒绝

在这里插入图片描述

根据"/admin/*"匹配模式,*便是任何路径都可,使用/admin/index%0a,成功绕过权限, %0a为换行符

Payload: /admin/index%0a

在这里插入图片描述

在这里插入图片描述

5 修复方案

官方补丁目前官方已修复该漏洞,受影响用户可以升级更新到安全版本。官方下载链接:https://spring.io/projects/spring-security

### 解析 Import Error 的常见原因 当遇到 `ImportError: cannot import name 'Generic'` 错误时,通常意味着尝试从模块中导入的对象不存在无法访问。此问题可能由多种因素引起: - 版本不兼容:不同库之间的版本冲突可能导致此类错误。 - 安装缺失:目标库未正确安装路径配置有误。 - 导入语句不当:可能存在循环依赖其他语法层面的问题。 ### 针对 Generic 类型的具体解决方案 对于特定于 `Generic` 的情况,考虑到 Python 中 `Generic` 是 typing 模块的一部分,在处理该类别的 ImportError 时可采取如下措施[^1]: #### 方法一:确认typing模块可用性 确保环境中已安装标准库中的 typing 模块,并且其版本支持所使用的特性。可以通过以下命令验证: ```bash python -c "from typing import Generic; print(Generic)" ``` 如果上述命令执行失败,则可能是由于 Python 者相关扩展包的版本过低造成的。此时应考虑升级至更高版本的解释器以及对应的开发工具链。 #### 方法二:调整导入方式 有时直接通过顶层命名空间来获取所需组件会更稳定可靠。修改代码以采用这种做法可能会解决问题: ```python from collections.abc import Iterable # 如果是迭代器相关接口 from typing import TypeVar, Protocol # 对于协议和泛型定义 T = TypeVar('T') class MyContainer(Protocol[T]): ... ``` 注意这里并没有显式提到 `Generic` ,而是利用了更为基础的数据结构抽象基类是其他替代方案实现相同功能[^2]。 #### 方法三:排查环境变量设置 检查系统的 PYTHONPATH 和虚拟环境配置是否正常工作。任何异常都可能导致某些第三方软件包找不到必要的资源文件而引发类似的错误提示。建议清理并重建项目专属的工作区以便排除干扰项的影响。 #### 示例修正后的代码片段 假设原始代码试图这样引入 `Generic` : ```python from some_module import Generic # 可能导致 ImportError ``` 改为遵循官方文档推荐的方式后变为: ```python from typing import Generic # 正确的做法 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值