大家都知道在Windows中"/"符号是路径的分隔符号,比如"C:/Windows/"的意思就是C分区的
Windows文件夹,"C:/Windows/System.exe"的意思就是C分区中的Windows文件夹中的System.exe文件,好继续我们假设一下:如果文件名中有"/"符号会怎么样呢?假如"S/"是一个文件夹的名字,这个文件夹位于:"F:/",他的路径就是"F:/S/",当我们试图访问的时候Windows会错误的认为我们要打开的文件是C分区的S文件夹,这样Windows就无法打开并且会返回一个错误,因为以上的路径并不存在.
也许你现在正在尝试创建"S/"文件,但是Windows会提示你:"/"符号是不能作为文件、文件夹的名字的"看来微软还是早已想到这一点了的"OK我们继续进行,就不信不能建立包含"/"符号的文件.
进入Windows后 点击:开始>运行 然后输入"cmd"并回车(如果是Win98请输入"COMMAND"),这时你会看到Windows的命令控制台,我们就是要利用它完成我们剩下的测试,以下{}中的字符是注释:
----------------------------------------------
Microsoft Windows XP [版本 5.1.2600]
(C) 版权所有 1985-2001 Microsoft Corp.
c:/mkdir s/ {我们的第一次尝试,结果Windows只创建了S文件夹"/"被忽略掉了}
c:/mkdir s/s1/ {还是失败,Windows先创建了S文件夹,然后在S内创建s1文件夹}
c:/mkdir s./ {"s./"被解析成S"./"又被忽略了}
子目录或文件 s./ 已经存在.
c:/mkdir s../ {终于成功了,现在你可以在资源管理器看到"s."但却无法打开/删除}
c:/mkdir s.../ {又成功了,在资源浏览器能看到"s.."可以打开但是无法删除}(ps:也是无法打开/删除)
----------------------------------------------
----------------------------------------------
1)原理:
为什么会这样?我们先说你看到的这个"S."文件夹,他即不能打开也不能删除,不能打开是因为他的实际路径是"c:/s../"(我们自己创建的所以可以确定他的实际路径)但是在Windows资源管理器中名字变成了"S."也就是说当你试图打开它的时候Windows实际上尝试打开"c:/s./"当然是不能打开的,文件并不存在,所以Windows会报错"不能删除也是因为这个,Windows把一个实际存在的文件路径错误的解析为一个不存在的路径,并进行操作当然是无法完成的.
该说"S.."这个文件了,这个文件可以打开(ps:也是打不开),但是却无法删除.等等……打开?你以
Windows真的是打开了我们创建的"s.../"文件了吗?我们做下面的试验你就明白了:
----------------------------------------------
Microsoft Windows XP [版本 5.1.2600]
(C) 版权所有 1985-2001 Microsoft Corp.
c:/copy 1.exe s.../ {复制刚刚你的木马、病毒文件到"s.../}
已复制 1 个文件.
c:/
----------------------------------------------
2)利用:
这是关键的话题了,其实我们就利用S.目录不被查杀的目的来隐藏我们的文件,
就算专业级的杀毒软件也查杀不了,
3)删除方法:
-----------------------------------------
Microsoft Windows XP [版本 5.1.2600]
(C) 版权所有 1985-2001 Microsoft Corp.
c:/rmdir s../
目录不是空的.
c:/rmdir s../ /s
s../, 是否确认(Y/N)? y
c:/rmdir s.../ /s
s.../, 是否确认(Y/N)? y
-----------------------------
4)缺点:
1.要在控制台下输入命令,不是很方便.(可以通过写一个窗口UI程序来解决)
2.好像只能向该文件夹内写入文件,而不能删除其中的文件.(如何删除请高手指点)