利用NTFS交换数据流隐藏文件
这篇文章介绍一下Windows的NTFS文件系统的ADS(alternate data streams,交换数据流)特性;实例演示如何利用ADS将文件隐藏到任何宿主上(宿主可以是文件夹、文件以及磁盘根目录);文章最后将提供两个小工具,利用它们来检测和清除隐藏在宿主上的文件。
文章目录
[*1*].什么是NTFS交换数据流(ADS)
NTFS交换数据流(alternate data streams,简称ADS)是NTFS磁盘格式的一个特性,在NTFS文件系统下,每个文件都可以存在多个数据流,就是说除了主文件流之外还可以有许多非主文件流寄宿在主文件流中。它使用资源派生来维持与文件相关的信息,虽然我们无法看到数据流文件,但是它却是真实存在于我们的系统中的。创建一个数据交换流文件的方法很简单,命令为“宿主文件:准备与宿主文件关联的数据流文件”。
这一段是百度百科上面的内容,大致了解一下即可,后面会有实例演示。
[*2*].NTFS交换数据流隐藏文件实例
这一部分内容在Windows XP、Windows 7、Windows 8的NTFS分区上都能适用,WinXP和Win7、Win8稍有不同,不同的地方会在文中说明。
实验环境:Windows 8
实验分区:E盘根目录-NTFS分区(ADS是NTFS文件系统的特性,不适用于FAT32文件系统)
在我的E盘根目录中有这些文件:
12 |
2012/12/15 21:03 5 123.txt |
13 |
2012/05/29 20:15 346,112 aaa.exe |
14 |
2012/09/26 07:36 72,294 bbb.jpg |
15 |
2012/01/04 04:10 61,952 lads.exe |
16 |
2012/04/27 10:17 87,424 streams.exe |
22 |
* lads.exe和streams.exe是用于检测交换数据流的程序,后面会用到, |
实验环境和所有用于实验的文件全部介绍完毕,下面开始实际操作 。
* 如何利用NTFS交换数据流隐藏文本文件
注意,下面的命令需要用“管理员身份”打开一个CMD,否则很可能执行不成功。
2 |
* 使用echo命令,将"hello"这几个字符写入到123.txt:222.txt中, |
3 |
* echo命令是以写字符的方式创建了123.txt:222.txt这个交换数据流文件, |
4 |
* 其中123.txt是宿主文件,222.txt是交换数据流文件, |
5 |
* 222.txt在图形界面下是不可见的,就像寄生虫一样,寄生在123.txt上。 |
7 |
E:\> echo hello>>123.txt:222.txt |
11 |
* 打开后可以添加删除222.txt的内容,但是不能另存为。 |
13 |
E:\>notepad 123.txt:222.txt |
16 |
* 将123.txt使用交换数据流的方式寄生到test文件夹上, |
17 |
* type命令和echo命令不同,type命令是将已经存在的一个文件, |
18 |
* 用交换数据流的方式寄生到另外一个文件或文件夹上, |
19 |
* test文件夹是一个空文件夹,寄生123.txt后,文件夹大小显示仍然是0。 |
21 |
E:\>type 123.txt>>test:123.txt |
24 |
* 使用notepad打开这个寄生在test上的文本文件, |
25 |
* 如果命令提示符是在其他盘符,可以使用这个数据流文件的完整路径来打开, |
27 |
* C:\>notepad E:\test:123.txt |
29 |
E:\>notepad test:123.txt |
32 |
E:\>type 123.txt>>E:\:123.txt |
35 |
* 通过相对路径来打开,也可以通过绝对路径来打开, |
36 |
* 命令是"E:\>notepad E:\:123.txt" |
这种方法能很好的将一个文本文件使用交换数据流的形式寄生在另外一个文件上(任何类型的文件上),从一定程度上起到了隐藏文本文件的目的。
* 如何利用NTFS交换数据流隐藏图片文件
图片文件也能寄生在任何类型的文件上,下面给出几个实例:
2 |
E:\>type bbb.jpg>>123.txt:bbb.jpg |
5 |
E:\>type bbb.jpg>>test:bbb.jpg |
8 |
E:\>type bbb.jpg>>aaa.exe:bbb.jpg |
11 |
E:\>type bbb.jpg>>E:\:bbb.jpg |
14 |
* 打开方式很简单,可以使用系统自带的图画程序mspaint, |
15 |
* 这里打开寄生在可执行文件中的那张图片,其他文件同理。 |
17 |
E:\>mspaint aaa.exe:bbb.jpg |
* 如何利用NTFS交换数据流隐藏可执行文件
WinXP和Win7、Win8在NTFS交换数据流的不同体现在对寄生的可执行文件的运行管理上,XP可以按照和上面相同的方法直接运行寄生的可执行程序;Win7、Win8上需要手动创建一个连接文件,通过这个链接文件才能运行这个寄生的交换数据流文件,下面请看演示:
1 |
/*寄生的方法和图片和文本文件相同,寄生到123.txt*/ |
2 |
E:\>type aaa.exe>>123.txt:aaa.exe |
5 |
E:\>type aaa.exe>>E:\:aaa.exe |
8 |
* XP中可以直接通过start命令使用绝对路径来调用这个寄生的可执行文件, |
9 |
* 但是在Win7和Win8中会出现下面的错误。 |
10 |
* (Win XP中start命令后面必须接绝对路径) |
下面是Win7和Win8中调用这个E盘根目录下的交换数据流可执行文件的方法:
2 |
* 在C盘的根目录中创建一个符号链接文件eee.exe, |
3 |
* 链接到E盘根目录中寄生的交换数据流可执行文件aaa.exe上。 |
5 |
E:\>mklink C:\eee.exe E:\:aaa.exe |
6 |
为 C:\eee.exe <> E:\:aaa.exe 创建的符号链接 |
8 |
/*在命令行下执行这个链接文件,即可运行E:\:aaa.exe*/ |
13 |
* 看到进程列表里面多出一个名称很奇怪的进程":aaa.exe", |
14 |
* 如果我们使用相同的方法运行寄生在文本文件中的那个aaa.exe, |
15 |
* 看到的进程名称就会是"123.txt:aaa.exe"。 |
在WinXP中,可执行文件可以和文本文件一样实现真正的隐藏,这可能也是当时大多数杀毒软件都添加数据流病毒查杀功能的原因;在Win7和Win8中,微软可能出于安全考虑,也可能是其他原因,不允许直接运行交换数据流可执行文件,必须要创建符号链接,默认这个符号链接是可见的(当然可以使用其他手段隐藏这个符号链接),并且这个符号链接创建出来后不能复制到其他地方,只能在创建的那个位置使用命令行方式调用(鼠标双击会报错)。
[*3*].如何检测和清除NTFS-ADS隐藏的文件
上面说了隐藏,现在来说检测,可以使用这两款小工具配合进行检测和清除寄生的交换数据流(百度网盘下载地址),工具都是命令行模式的,请看下面的演示:
2 |
* 将这lads.exe这个程序放置需要检测的分区根目录中, |
3 |
* 不添加任何参数直接运行,就是检测根目录中所有文件, |
4 |
* 如果使用"lads.exe test /S",就是递归检测test以及test下所子目录。 |
9 |
Scanning directory E:\ with subdirectories |
12 |
---------- --------------------------------- |
17 |
346112 E:\123.txt:aaa.exe |
18 |
72294 E:\123.txt:bbb.jpg |
19 |
72294 E:\aaa.exe:bbb.jpg |
21 |
72294 E:\test\:bbb.jpg |
23 |
1053737 bytes in 9 ADS listed |
27 |
/*可以看到我们实验中添加的所有交换数据流一览无遗*/ |
使用streams.exe这个程序来清除这些交换数据流,根据上面检测的输出信息,我将streams.exe放在E盘的根目录:
2 |
* 首先尝试清除一下E盘根目录上面寄生的交换数据流, |
10 |
* 这里出现了一个错误,因为这个:aaa.exe现在正在运行 |
11 |
* 对于这种情况,需要先结束掉这个:aaa.exe进程才能清除。 |
13 |
Error deleting :aaa.exe: $DATA : |
15 |
Deleted :bbb.jpg: $DATA |
17 |
/*可以添加-s参数来一次性递归清除E盘下所有寄生的交换数据流文件*/ |
18 |
E:\>streams.exe -s -d E:\ |
21 |
Deleted :222.txt: $DATA |
22 |
Deleted :aaa.exe: $DATA |
23 |
Deleted :bbb.jpg: $DATA |
25 |
Deleted :bbb.jpg: $DATA |
27 |
Deleted :123.txt: $DATA |
28 |
Deleted :bbb.jpg: $DATA
|
- UNCTF杂项题Hidden secret 之NTFS交换数据流隐写
---恢复内容开始--- 做这道题目的经历比较坎坷,题目中用于隐藏flag的jpg文件出了问题,导致不能被交换数据流隐写所以出题人换了一次题目,最后做法也换了,不过出题人一开始的考察点还是基于NTFS ...
- NTFS交换数据流隐写的应用
by Chesky ##目录 ####一.NTFS交换数据流(ADS)简介 ####二.ADS应用 写入隐藏文件(文本\图像\可执行文件) ADS在Windows平台下的利用--写入后门 ADS在We ...
- NTFS的交换数据流ADS应用
NTFS的交换数据流ADS应用 NTFS是Windows常用的文件系统格式.该格式支持交换数据流(Alternate Data Streams,缩写ADS)特性.该特性可以让多个文件流使用同一个文 ...
- NTFS系统的ADS交换数据流
VC++ 基于NTFS的数据流创建与检测 What are Alternate Streams?(交换数据流) NTFS alternate streams , 或者叫streams,或者叫ADS(w ...
- 利用NTFS权限与虚拟目录,在IIS 6.0的默认FTP站点中做用户隔离。
默认FTP站点为不隔离用户站点,利用NTFS权限设置,达到仅能访问指定目录效果. 是否允许匿名连接 FTP站点主目录:站点范围内有没有用户需要上传,有的话,要勾选“写入”:具体用户使用NTFS还给予写 ...
- Windows Server 2008利用NTFS管理数据
今天我们学习关于NTFS管理数据 以下是学习的内容NTFS分区和FAT32分区的区别,如何将FAT32分区转化成NTFS分区,FAT 32 不支持大于4G ,NTFS权限设置 ,EFS加密 ,文件夹的 ...
- java利用反射交换两个对象中的字段相同的字段值
有时候我们的两个对象字段都是一样的,只有极少的区别,想要把一个对象字段的值,赋值给另外一个对象值 然后传给另外一个方法使用,但是这个字段太多,一个一个的复制太过繁琐. 这时候利用反射解决这个问题. c ...
- TCP交换数据流——Nagle算法简单记录
Nagle算法: 该算法提出的目的是想解决网络中大量的小的TCP数据包造成网络拥塞的问题,举个例子,当客户端要发送一个字节的TCP数据包到服务器时,我们实际上产生了41字节长的分组:包括20字节的IP ...
- BugkuCTF——wp(旧版)
title: BugkuCTF--wp(旧版) date: 2020-4-25 tags: CTF,比赛 categories: CTF 比赛 Web篇 0x001-web2 解题思路: 1.直接按F ...
随机推荐
- java 集合(Map3)
Map接口下的实现类: HashMap 1.存储原理: 向HashMap中添加元素时,首先会调用hashCode(),算的哈希值,然后 算出该元素在哈希表中的存储位置. 情况1 情况2(java 集 ...
- 有关mipmaps
Mipmaps的作用是什么,仅仅是为了使屏幕三角形和纹理三角形的差异变小?有没有以空间换时间的理念? Mipmaps在生成一系列小的纹理样本时, 是如何从原始纹理采样的?即如何生成这些小的纹理样本.
- MySQL 函数积累
IFNULL(expr1,expr2) // 如果expr1不是NULL,IFNULL()返回expr1,否则它返回expr2.IFNULL()返回一个数字或字符串值 IF(expr1,expr2,e ...
- 工作日志 jquery slideDown slideUp
jquery里面使用 slideDown 和 slideUp会有一个像素的偏差
- openCV1
openCV是一个提供有C++ , android , python的开源图像处理的类库 中文论坛的网址是http://www.opencv.org.cn/forum.php?mod=forumdis ...
- hdu----(3068)最长回文(manacher)
最长回文 Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
- Hibernate缓存机制
缓存是介于应用程序和物理数据源之间,其作用是为了降低应用程序对物理数据源访问的频次,从而提高了应用的运行性能.缓存内的数据是对物理数据源中的数据的复制,应用程序在运行时从缓存读写数据,在特定的时刻或事 ...
- 10个必备的移动UI设计资源站(转)
创建移动设计模式是非常重要的一步,记住!这是为移动设备设计而不是web.不仅仅是移动屏幕远小于普通的电脑屏幕,关键是鼠标和键盘已经被手指替代了! 当然还有更重要的,说起来很苦逼,我们再也不能使用一种模 ...
- LeetCode 423. Reconstruct Original Digits from English——学会观察,贪心思路
Given a non-empty string containing an out-of-order English representation of digits 0-9, output the ...
- 陈朱兴-js写法【案例】:
ajax请求: 一.从服务器端请求数据: var url = '';url = 'https://api.weixin.qq.com/sns/oauth2/access_token?appid='+ ...