计算机之家
图片广告


 
标题: 驱 动 级 隐 藏 木 马 ( Rootkit ) - PcShare 查 杀 手 记
计算机之家
论坛VIP
Rank: 9Rank: 9Rank: 9
版主


VIP会员   论坛元老  
UID 127
精华 7
积分 1331
帖子 707
威望 1261
现金 1634 币币
存款 0 币币
阅读权限 10
注册 2005-11-2
状态 离线
 
发表于 2005-11-20 21:59  资料  个人空间  短消息  加为好友            
驱 动 级 隐 藏 木 马 ( Rootkit ) - PcShare 查 杀 手 记

PcShare简介:
一款计算机远程控制软件,采用HTTP反向通信,屏幕数据线传输,驱动隐藏端口通信过程等技术,达到系统级别的隐藏。类似灰鸽子,由于结合了最新的Rootkit技术,用一般的系统扫描软件如Hijackthis等无法检测到其木马服务信息,最近有泛滥的趋势...
PcShare样本(arcldrer.exe)运行后释放文件有:
%System32%\Ybfbqufe.d1l
%System32%\Ybfbqufe.dll
%System32%\drivers\Ybfbqufe.sys
插入并启动IE隐藏进程:
在注册表中添加了隐藏的驱动服务:
[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Ybfbqufe]
[HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\Ybfbqufe]
指向%SystemRoot%\System32\drivers\Ybfbqufe.sys
如果是XP系统:
修改dmserver服务(监测和监视新硬盘驱动器并向逻辑磁盘管理器管理服务发送卷的信息以便配置):
[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\dmserver\Parameters]
[HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\dmserver\Parameters]
[HKEY_LOCAL_MACHINE\SYSTEM\ControlSet002\Services\dmserver\Parameters]
指向病毒文件:
"ServiceDll"="%System32%\Ybfbqufe.d1l"
如果此服务被终止,动态磁盘状态和配置信息会过时。如果此服务被禁用,任何依赖它的服务将无法启动。
如果是2000系统:
修改RpcSs服务(Remote
Procedure Call
Services):
[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\RpcSs\Parameters]
[HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\RpcSs\Parameters]
[HKEY_LOCAL_MACHINE\SYSTEM\ControlSet002\Services\RpcSs\Parameters]
指向病毒文件:
"ServiceDll"="%System32%\Ybfbqufe.d1l"
rpcss.exe是微软Windows操作系统的一部分。它用于本地计算机的远程程序调用
服务。它是本地网络的公用服务。这个程序对系统的正常运行是非常重要的。





欢迎大家光临鲁大翻译论坛 [url] http://www.ld-translation.cn [/url]
顶部
计算机之家
论坛VIP
Rank: 9Rank: 9Rank: 9
版主


VIP会员   论坛元老  
UID 127
精华 7
积分 1331
帖子 707
威望 1261
现金 1634 币币
存款 0 币币
阅读权限 10
注册 2005-11-2
状态 离线
 
发表于 2005-11-20 21:59  资料  个人空间  短消息  加为好友 
清除(以2000系统为例):
1,工具准备:由于驱动级(Rootkit)木马运行级别的特殊性,在正常模式下无论是木马施放文件还是对于注册表的改动都是无法观测到的,从而达到木马隐藏的目的,要侦测到隐藏的信息,我们需要借用同样内核级的工具-IceSword,其使用了大量新颖的内核技术,使得这些后门无处可躲,具备反隐藏、反保护的功能,基本上所有的木马都可以检测出来。最新版本下载地址:ftp://202.38.76.151/pub2/Kernel/Windows/tools/IceSword1.12.rar
通过IceSword进程查看功能即可看到隐藏的木马进程(图中红色显示):



通过IceSword的SSDT(系统服务描述符表)查看功能可查看到隐藏的木马驱动:






欢迎大家光临鲁大翻译论坛 [url] http://www.ld-translation.cn [/url]
顶部
计算机之家
论坛VIP
Rank: 9Rank: 9Rank: 9
版主


VIP会员   论坛元老  
UID 127
精华 7
积分 1331
帖子 707
威望 1261
现金 1634 币币
存款 0 币币
阅读权限 10
注册 2005-11-2
状态 离线
 
发表于 2005-11-20 22:01  资料  个人空间  短消息  加为好友 
2,由于木马进程的保护功能,我们首先需要在IceSword的文件-设置下勾选相关功能,如图所示。



3,设置完毕后结束掉木马进程,利用IceSword注册表编辑功能,分别定位注册表到:[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Ybfbqufe]
[HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\Ybfbqufe]
并删除Ybfbqufe主键。



4,利用IceSword文件查看功能,找到以下文件并删除:
%System32%\Ybfbqufe.d1l
%System32%\Ybfbqufe.dll



删除:
%System32%\drivers\Ybfbqufe.sys



5,恢复注册表中的服务改动,分别定位注册表到:
[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\RpcSs\Parameters]
[HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\RpcSs\Parameters]
[HKEY_LOCAL_MACHINE\SYSTEM\ControlSet002\Services\RpcSs\Parameters]
将"ServiceDll"="%System32%\Ybfbqufe.d1l"修改为正常的目录文件"ServiceDll"="%System32%\rpcss.d1l"
XP系统需要恢复的注册表为:
[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\dmserver\Parameters]
[HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\dmserver\Parameters]
[HKEY_LOCAL_MACHINE\SYSTEM\ControlSet002\Services\dmserver\Parameters]
正常的目录文件应为"ServiceDll"="%SystemRoot%\System32\dmserver.dll"



6,重启系统后免疫:[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Schedule]不存在的话,PcShare服务端就发生异常终止运行(本人未经证实),所以我们只要删除注册表中的[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Schedule]主键就可以达到免疫的效果了。

总结:
清除此类驱动级木马,关键是对于隐藏进程的查看于结束和注册表服务项的删除,对于被木马篡改的系统服务,在不确定的状况下,建议搜索相关确定信息或找相同系统机器查看再做恢复。

附Rootlit技术简介:
如自然界的规则一样,最流行的病毒,对生物的伤害却是最小的,例如一般的感冒,但是最不流行的病毒,却是最夺命的。Rootkit木马就是信息世界里的AIDS,一旦感染,就难以用一般手段消灭了,因为它和自然界里的同类做的事情一样,破坏了系统自身检测的完整性——抛开术语的描述也许难以理解,但是可以配合AIDS的图片想象一下,由于AIDS破坏了人体免疫系统,导致白细胞对它无能为力,只能眼睁睁看着人体机能被慢慢破坏。计算机系统没有免疫功能,但是它提供了对自身环境的相关检测功能——枚举进程、文件列表、级别权限保护等,大部分杀毒软件和进程工具都依赖于系统自带的检测功能才得以运作,而Rootkit木马要破坏的,正是这些功能。
要了解Rootkit木马的原理,就必须从系统原理说起,我们知道,操作系统是由内核(Kernel)和外壳(Shell)两部分组成的,内核负责一切实际的工作,包括CPU任务调度、内存分配管理、设备管理、文件操作等,外壳是基于内核提供的交互功能而存在的界面,它负责指令传递和解释。由于内核和外壳负责的任务不同,它们的处理环境也不同,因此处理器提供了多个不同的处理环境,把它们称为运行级别(Ring),Ring让程序指令能访问的计算机资源依次逐级递减,目的在于保护计算机遭受意外损害——内核运行于Ring
0级别,拥有最完全最底层的管理功能,而到了外壳部分,它只能拥有Ring
3级别,这个级别能操作的功能极少,几乎所有指令都需要传递给内核来决定能否执行,一旦发现有可能对系统造成破坏的指令传递(例如超越指定范围的内存读写),内核便返回一个“非法越权”标志,发送这个指令的程序就有可能被终止运行,这就是大部分常见的“非法操作”的由来,这样做的目的是为了保护计算机免遭破坏,如果外壳和内核的运行级别一样,用户一个不经意的点击都有可能破坏整个系统。
由于Ring的存在,除了由系统内核加载的程序以外,由外壳调用执行的一般程序都只能运行在Ring
3级别,也就是说,它们的操作指令全部依赖于内核授权的功能,一般的进程查看工具和杀毒软件也不例外,由于这层机制的存在,我们能看到的进程其实是内核“看到”并通过相关接口指令(还记得API吗?)反馈到应用程序的,这样就不可避免的存在一条数据通道,虽然在一般情况下它是难以被篡改的,但是不能避免意外的发生,Rootkit正是“制造”这种意外的程序。简单的说,Rootkit实质是一种“越权执行”的应用程序,它设法让自己达到和内核一样的运行级别,甚至进入内核空间,这样它就拥有了和内核一样的访问权限,因而可以对内核指令进行修改,最常见的是修改内核枚举进程的API,让它们返回的数据始终“遗漏”Rootkit自身进程的信息,一般的进程工具自然就“看”不到Rootkit了。更高级的Rootkit还篡改更多API,这样,用户就看不到进程(进程API被拦截),看不到文件(文件读写API被拦截),看不到被打开的端口(网络组件Sock
API被拦截),更拦截不到相关的网络数据包(网络组件NDIS
API被拦截)了,幸好网络设备的数据指示不受内核控制,否则恐怕Rootkit要让它也不会亮了才好!我们使用的系统是在内核功能支持下运作的,如果内核变得不可信任了,依赖它运行的程序还能信任吗?但即使是Rootkit这一类恐怖的寄生虫,它们也并非所向无敌的,要知道,既然Rootkit是利用内核和Ring
0配合的欺骗,那么我们同样也能使用可以“越权”的检查程序,绕过API提供的数据,直接从内核领域里读取进程列表,因为所有进程在这里都不可能把自己隐藏,除非它已经不想运行了。也就是说,内核始终拥有最真实的进程列表和主宰权,只要能读取这个原始的进程列表,再和进程API枚举的进程列表对比,便能发现Rootkit进程,由于这类工具也“越权”了,因而对Rootkit进行查杀也就不再是难事,而Rootkit进程一旦被清除,它隐藏自身的措施也就不复存在,内核就能把它“供”出来了,用户会突然发现那个一直“找不到”的Rootkit程序文件已经老实的呆在文件管理器的视图里了。这类工具现在已经很多,例如IceSword、Patchfinder、gdb等。





欢迎大家光临鲁大翻译论坛 [url] http://www.ld-translation.cn [/url]
顶部
luntan32
论坛VIP
Rank: 9Rank: 9Rank: 9
会员


VIP会员   论坛元老  
UID 14
精华 3
积分 202
帖子 1437
威望 172
现金 2951 币币
存款 217 币币
阅读权限 10
注册 2005-10-21
来自 上海
状态 离线
 
发表于 2005-11-21 00:20  资料  个人空间  短消息  加为好友 
不错 先学着点 谢谢

顶部
 

 
 
当前时区 GMT+8, 现在时间是 2008-12-2 08:25