转载:NTFS交换数据流实验(晴刃原创)



该文由 晴刃(QingSword.COM)  原创;

原文题目:利用NTFS交换数据流隐藏文件

原文连接:http://www.qingsword.com/qing/812.html

转载以备资料参考,在原文基础上根据实际有备注和更改 如有侵犯,即刻删除 感谢理解分享

------------------------------------------------------------------------------------------------------------------------------------------------------

引言

这篇文章介绍Windows下NTFS文件系统的ADS(alternate data streams,交换数据流)特性;实例演示如何利用ADS将文件隐藏到任何宿主上(宿主可以是文件夹、文件以及磁盘根目录);文章最后将提供两个小工具,利用它们来检测和清除隐藏在宿主上的文件。


文章目录


0×1.什么是NTFS交换数据流(ADS)

NTFS交换数据流(alternate data streams,简称ADS)是NTFS磁盘格式的一个特性,在NTFS文件系统下,每个文件都可以存在多个数据流,就是说除了主文件流之外还可以有许多非主文件流寄宿在主文件流中。它使用资源派生来维持与文件相关的信息,虽然我们无法看到数据流文件,但是它却是真实存在于我们的系统中的。创建一个数据交换流文件的方法很简单,命令为"宿主文件:准备与宿主文件关联的数据流文件"。

这一段是百科上面的内容,大致了解一下即可,后面会有实例演示。

0×2.NTFS交换数据流隐藏文件实例

这一部分内容在Windows系列操作系统的NTFS分区上都能适用。

实验环境:Windows 10
实验分区:E盘根目录(NTFS分区,ADS是NTFS文件系统的特性,不适用于FAT32文件系统)

在E盘根目录中有这些文件:

01/*切换到E盘根目录*/
02C:\Windows\System32>e:  /* C:\Windows\System32>表示以管理员身份"打开CMD
03E:\>
04 
05/*查看E盘根目录中有哪些内容*/
06E:\>dir
07 
082012/12/15  21:03          5 123.txt
092012/05/29  20:15    346,112 aaa.exe
102012/09/26  07:36     72,294 bbb.jpg
112012/01/04  04:10     61,952 lads.exe
122012/04/27  10:17     87,424 streams.exe
132012/12/15  21:12            test
14/*
15 * 123.txt 是一个文本文件,
16 * aaa.exe 是一个可执行文件,
17 * bbb.jpg 是一张图片,
18 * lads.exe和streams.exe是用于检测交换数据流的程序,后面会用到,
19 * test是一个空文件夹。
20 */

实验环境和所有用于实验的文件全部介绍完毕,下面开始实际操作 。

a.如何利用NTFS交换数据流隐藏文本文件

注意,下面的命令需要用"管理员身份"打开CMD,否则很可能执行不成功。

01/*
02 * 使用echo命令,将"www.qingsword.com"这几个字符写入到123.txt:222.txt中,
03 * echo命令以写字符的方式创建了":222.txt"这个交换数据流文件,
04 * 其中123.txt是宿主文件,222.txt是交换数据流文件,
05 * 222.txt在图形界面下是不可见的,就像寄生虫一样,寄生在123.txt上。
06 */
07E:\>echo www.qingsword.com>>123.txt:222.txt
08 
09/*
10 * 使用记事本程序打开这个交换数据流文件,
11 * 打开后可以添加删除222.txt的内容并保存,但是不能另存为。
12 */
13E:\>notepad 123.txt:222.txt /*显示内容为:www.qingsword.com, echo www.baidu.com>123.txt:222.txt,新输入的www.baidu.com会覆盖www.qingsword.com,” >是覆盖,>>是追加”
14 
15/*
16 * 将123.txt使用交换数据流的方式寄生到test文件夹上,
17 * type命令和echo命令不同,type命令是将已经存在的一个文件,
18 * 用交换数据流的方式寄生到另外一个文件或文件夹上,
19 * test文件夹是一个空文件夹,寄生123.txt后,文件夹大小显示仍然是0。
20 */
21E:\>type 123.txt>>test:123.txt /*为体现实验效果 echochangjiang>>123.txt 123.txt中只有changjiang
22 
23/*
24 * 使用notepad打开这个寄生在test上的文本文件,
25 * 如果命令提示符是在其他盘符,可以使用这个数据流文件的完整路径来打开,
26 * 比如当前盘符在C盘,可以这样打开:
27 * "C:\>notepad E:\test:123.txt"
28 */
29

E:\>notepad test:123.txt

/*内容与123.txt一致changjiang


/*实验将原文件123.txt内容改动,看test:123.txt是否自动随之更改(答案是NO


Echohanghe>>123.txt /*123.txt内容为changjiang hanghe


notepad test:123.txt /*内容依然为changjiang


实验:寄生的交换数据流能否再寄生?


type 123.txt:222.txt >>test:222.txt NO!!!!!!!!!!!!!!


type 123.txt:222.txt >>test:123.txt:222.txt NO!!!!!!


所以 交换数据流不再多次寄生



30 
31/*将123.txt寄生到E盘根目录*/
32E:\>type 123.txt>>E:\:123.txt /*为方便后面的交换数据流删除,我上述所有的实验文件都放在我放在d:\sandbox下type 123.txt>>d:\sandbox:123.txt
33 
34/*
35 * 通过相对路径来打开,也可以通过绝对路径来打开,
36 * 命令是"E:\>notepad E:\:123.txt"
37 */
38E:\>notepad :123.txt

这种方法能很好的将一个文本文件使用交换数据流的形式寄生在另外一个文件上(任何类型的文件上),从一定程度上起到了隐藏文本文件的目的。

b.如何利用NTFS交换数据流隐藏图片文件

图片文件也能寄生在任何类型的文件上,下面给出几个实例:

01/*寄生到123.txt上*/
02E:\>type bbb.jpg>>123.txt:bbb.jpg
03 
04/*寄生到test文件夹上*/
05E:\>type bbb.jpg>>test:bbb.jpg
06 
07/*寄生到aaa.exe这个可执行文件上*/
08E:\>type bbb.jpg>>aaa.exe:bbb.jpg
09 
10/*寄生到E盘根目录*/
11E:\>type bbb.jpg>>E:\:bbb.jpg
12 
13/*
14 * 打开方式很简单,可以使用系统自带的图画程序mspaint,
15 * 这里打开寄生在可执行文件中的那张图片,其他文件同理。
16 */
17E:\>mspaint aaa.exe:bbb.jpg

c.如何利用NTFS交换数据流隐藏可执行文件

WinXP和Win7之后的Windows版本在NTFS交换数据流的不同体现在对寄生的可执行文件的运行管理上,XP可以按照和上面相同的方法直接运行寄生的可执行程序;Win7之后的版本需要手动创建一个连接文件,通过这个链接文件才能运行这个寄生的可执行交换数据流文件,请看下面的实例:

01/*寄生的方法和图片和文本文件相同,寄生到123.txt*/
02E:\>type aaa.exe>>123.txt:aaa.exe
03 
04/*寄生到E盘根目录*/
05E:\>type aaa.exe>>E:\:aaa.exe
06 
07/*
08 * XP中可以直接通过start命令使用绝对路径来调用这个寄生的可执行文件,
09 * 但是在Win7之后的系统中会出现下面的错误。
10 * (Win XP中start命令后面必须接绝对路径)
11 */
12E:\>start E:\:aaa.exe
13系统找不到文件 E:\:aaa.exe。

下面是Win:7后的版本中调用这个E盘根目录下的交换数据流可执行文件的方法:

01/*
02 * 在C盘的根目录中创建一个符号链接文件eee.exe,
03 * 链接到E盘根目录中寄生的交换数据流可执行文件aaa.exe上。
04 */
05E:\>mklink C:\eee.exe E:\:aaa.exe
06为 C:\eee.exe <> E:\:aaa.exe 创建的符号链接
07 
08/*在命令行下执行这个链接文件,即可运行E:\:aaa.exe*/
09E:\>C:\eee.exe
10 
11/*
12 * 这个时候大家可以打开任务管理器,
13 * 看到进程列表里面多出一个名称很奇怪的进程":aaa.exe"
14 * 如果我们使用相同的方法运行寄生在文本文件中的那个aaa.exe,
15 * 看到的进程名称就会是"123.txt:aaa.exe"
16 */

在WinXP中,可执行文件可以和文本文件一样实现真正的隐藏,这可能也是当时大多数杀毒软件添加数据流病毒查杀功能的原因;在Win7之后的系统中,微软可能出于安全考虑,不允许直接运行交换数据流可执行文件,必须要创建符号链接,这个符号链接是可见的(当然可以使用其他手段隐藏这个符号链接),并且这个符号链接创建出来后不能复制到其他地方,只能在创建的那个位置使用命令行方式调用(鼠标双击会报错)。

0×3.如何检测和清除NTFS-ADS隐藏的文件

上面说了隐藏,现在来说检测,可以使用这两款小工具配合进行检测和清除寄生的交换数据流[网盘下载],工具都是命令行模式的,请看下面的演示:

01/*
02 * 将这lads.exe这个程序放置需要检测的分区根目录中,
03 * 不添加任何参数直接运行,就是检测根目录中所有文件,
04 * 如果使用"lads.exe test /S",就是递归检测test以及test下所子目录。
05 * 下面这条命令是检测根目录以及所有子目录。
06 */
07E:\>lads.exe /S
08 
09Scanning directory E:\ with subdirectories
10 
11      size  ADS in file
12----------  ---------------------------------
13        12  E:\:123.txt
14    346112  E:\:aaa.exe
15    144588  E:\:bbb.jpg
16         7  E:\123.txt:222.txt
17    346112  E:\123.txt:aaa.exe
18     72294  E:\123.txt:bbb.jpg
19     72294  E:\aaa.exe:bbb.jpg
20        12  E:\test\:123.txt
21     72294  E:\test\:bbb.jpg
22 
23   1053737 bytes in 9 ADS listed
24 
25/*可以看到我们实验中添加的所有交换数据流一览无遗*/

使用streams.exe这个程序来清除这些交换数据流,根据上面检测的输出信息,我将streams.exe放在E盘的根目录:

01/*
02 * 首先尝试清除一下E盘根目录上面寄生的交换数据流,
03 * -d后面接目录。
04 */
05E:\>streams.exe -d E:\
06 
07E:\:
08   Deleted :123.txt:$DATA
09/*
10 * 这里出现了一个错误,因为这个:aaa.exe现在正在运行
11 * 对于这种情况,需要先结束掉这个:aaa.exe进程才能清除。
12 */
13   Error deleting :aaa.exe:$DATA:
14?????
15   Deleted :bbb.jpg:$DATA
16 
17/*可以添加-s参数来一次性递归清除E盘下所有寄生的交换数据流文件(慎用,尤其是对系统盘一定不要随便使用递归清除,系统本身的一些数据流也会被一起清除掉)*/
18E:\>streams.exe -s -d E:\
19 
20E:\123.txt:
21   Deleted :222.txt:$DATA
22   Deleted :aaa.exe:$DATA
23   Deleted :bbb.jpg:$DATA
24E:\aaa.exe:
25   Deleted :bbb.jpg:$DATA
26E:\test:
27   Deleted :123.txt:$DATA
28   Deleted :bbb.jpg:$DATA


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值