(Win)文件上传数据流绕过-面试常考

之前一篇文章已经对简单的文件上传绕过做出总结:

文件上传绕过保姆篇,这篇主要是一些更高级的绕过,算是平时未涉及的一些补充

文件上传数据流绕过

利用 Windows NTFS 文件系统的备用数据流(Alternate Data Streams,ADS)特性

在 NTFS 文件系统中,一个文件除了默认的主数据流($DATA)外,还可以附加多个命名数据流 。这些流可以独立存储数据 ,但在常规操作(如 dir、文件大小查看、文本编辑器)中通常不可见。

关键的语法是:

复制代码
# 写入文件备用数据流:此时文件为空
Echo 111 > test.txt:1.txt	 	 
# 写入默认的主数据流:此时相当于写入文件内容
Echo test > test.txt
# 显示写入主数据流,文件存在内容
Echo 222  > test.txt::$data	 	

其中 ::$DATA 代表默认的主数据流。例如:test.php 实际等价于 test.php::$DATA

文件名后缀 ::$DATA 绕过扩展名检查

很多上传过滤逻辑是用正则、字符串函数来提取文件后缀的。例如后端代码:

如果攻击者上传的文件名是 shell.php::$DATA(也就是前篇文章提出的)

  • Windows 在创建文件时会自动去掉末尾的 ::$DATA ,最终落盘的文件名还是 shell.php

  • 但上面的 pathinfo 可能提取到 ::$DATA 作为扩展名,或者认为后缀是空,从而通过校验。

利用 ADS 隐藏 Webshell 并包含执行

攻击者可以上传一个完全合法的图片文件(例如 pic.jpg),但将 Webshell 代码写到它的 ADS 中:pic.jpg:shell.php

如果服务器存在文件包含漏洞 ,并且 include 函数能处理 ADS 路径(某些 PHP 版本 + Windows 环境),就可以这样执行:include 'uploads/pic.jpg:shell.php';

此时 PHP 会读取 ADS 中的 shell.php 内容并解析,从而在不破坏主文件(图片)的情况下执行恶意代码。

绕过内容检测(配合 NTFS 流)

一些上传接口会检查文件头(如 getimagesize)。攻击者可以:

  • 上传一个正常的图片,其 ADS 中嵌入 PHP 代码。

  • 或者利用文件名 test.php:image.jpg 上传,一些解析库可能只读取默认流(图片)内容来判断类型,从而放过 PHP 代码。

相关推荐
薛定猫AI4 分钟前
【深度解析】ChatGPT vs Claude vs Gemini:2026年AI大模型选型全景对比
大数据·网络·人工智能
砍材农夫7 分钟前
物联网实战:Spring Boot + Netty 搭建 MQTT 统一接入层
java·网络·spring boot·后端·物联网·spring
yangzhenzephyr7 分钟前
TCP流量控制与拥塞控制
网络·tcp/ip
X7x58 分钟前
PDR模型:构建网络安全的黄金三角
网络安全·网络攻击模型·安全威胁分析·安全架构·pdr模型
terry6009 分钟前
2026携号转网查询接口深度测评:技术指标、接入教程与服务商选型
大数据·人工智能·web安全·信息与通信·数据库架构
xhtdj10 分钟前
BadHost 漏洞使AI 代理评估器和LLM 网关面临风险
安全
zyplayer-doc10 分钟前
zyplayer-doc 文档管理系统深度评测:私有化部署下的安全与智能边界
安全·开源软件
这个人需要休息21 分钟前
优惠卷类型漏洞---优惠卷的并发使用
mysql·网络安全·逻辑漏洞·后端架构
小五传输21 分钟前
宏病毒查杀效率提升80%:2026年宏病毒查杀自动化方案详解
大数据·运维·安全
rockmelodies21 分钟前
Suricata_Binary_Protocol_Detection_Guide
安全·suricata·入侵检测