漏洞原理
Spring WebFlow 是一个适用于开发基于流程的应用程序的框架(如购物逻辑),可以将流程的定义和实现流程行为的类和视图分离开来。在其 2.4.x 版本中,如果我们控制了数据绑定时的field,将导致一个SpEL表达式注入漏洞,最终造成任意命令执行。
影响版本
Spring WebFlow 2.4.0 – 2.4.4
环境搭建
1 | cd /vulhub/spring/CVE-2017-4971/ |
等待环境启动后,访问http://your-ip:8080
,将看到一个酒店预订的页面,这是spring-webflow
官方给的简单示例。
漏洞复现
首先访问http://your-ip:8080/login
,用页面左边给出的任意一个账号/密码登录系统: