|
马上注册,结识高手,享用更多资源,轻松玩转三维网社区。
您需要 登录 才可以下载或查看,没有帐号?注册
x
全面瞭解系统中 svchost.exe 档案4 Q6 U) |6 ~& J5 r r
# Z7 E8 Y: b" l! R% ~* H9 F1 L笔者经常在一些反病毒论坛上浏览时,发现一些朋友对任务管理器中的svchost进度不甚瞭解,看见存在许多svchost进度就以为自己中了病毒,其实不然。
+ O! R! a5 f% Y/ e9 r! K1 K6 H' t% @! a9 |, g0 S
svchost.exe是NT核心系统非常重要的档案,对于Win2000/XP来说,不可或缺。这些svchost进度提供很多系统服务,如:rpcss服务(remote procedure call)、dmserver服务(logical disk manager)、dhcp服务(dhcp client)等等。2 l; N3 Z7 T- \4 @+ x9 D2 w5 B( s9 K
" b* B; a. t; D. u
若果要瞭解每个svchost进度到底提供了多少系统服务,可以在WinXP的指令提示符视窗中输入“tasklist /svc”指令来检视。4 T0 G6 n% w( i8 p$ n
l/ D! X) \7 Z; q6 }: { 工作原理/ r6 V' d; l# ]/ o3 ^4 z: |
9 B9 x f1 ~' Y, L- i) j 一般来说,Windows系统进度分为独立进度和共享进度两种。svchost.exe档案存在于%systemroot%\system32目录下,属于共享进度。
- ]5 e5 r2 x! D: C/ H6 W( V' W7 c Q9 r) ~
随着Windows系统服务不断增多,为了节省系统资源,微软把很多服务都做成共享模式,交由svchost进度来启动。但svchost进度只作为服务宿主,并不能实现任何服务功能,即它只能提供条件让其他服务在这里被启动,而它自己却不能给使用者提供任何服务。
* [9 y4 ^8 d5 ?
5 l0 w2 r$ F, S% K8 f& Y" O 这些服务是如何实现的呢?原来这些系统服务是以动态连结库(dll)形式实现的,它们把可执行程式指向svchost,由svchost呼叫相应服务的动态连结库来启动服务。+ t3 o2 N! q' ?
9 E O0 Y9 T1 ]( ^ 那svchost又怎么知道某个系统服务该呼叫哪个动态连结库呢?这是通过系统服务在注册表中设定的参数来实现的。5 ~' z: O- u" L$ |6 V& K3 I
) N9 A8 p7 e% k
具体案例2 p3 E# Z$ q/ n7 p
/ p4 m/ X, }) N% n4 w
下面以Remote Registry服务为例,来看看svchost进度是如何呼叫DLL档案的。在WinXP中,点击“开始→执行”,输入“services.msc”指令,会跳出服务对话框,然后开启“Remote Registry”属性对话框,可以看到Remote Registry服务的可执行档案的路径为“C:\Windows\System32\svchost -k LocalService”,这说明Remote Registry服务是依靠svchost呼叫“LocalService”参数来实现的,而参数的内容则是存放在系统注册表中的。
9 S7 i" P" A6 C9 s$ b- ~2 l2 ~" P4 e( C8 f2 \9 f
在执行对话框中输入“regedit.exe”后Enter,开启注册表编辑器,找到“HKEY_LOCAL_MACHINE\System\currentcontrolset\services\Remote Registry”项,再找到类型为“reg_expand_sz”的“Imagepath”项,其键值为“%systemroot%\system32\svchost -k LocalService”(这就是在服务视窗中看到的服务启动指令),另外在“parameters”次基码中有个名为“ServiceDll”的键,其值为“% systemroot%\system32\regsvc.dll”,其中“regsvc.dll”就是Remote Registry服务要使用的动态连结库档案。这样svchost进度通过读取“Remote Registry”服务注册表讯息,就能启动该服务了。$ n4 M9 U: Q- p. n6 ]5 I
4 Q& Q( ?) K- d: o" Y! b: b) f( y! Z' G 也正是因为svchost的重要性,所以病毒、木马也想尽办法来利用它,企图利用它的特性来迷惑使用者,达到感染、入侵、破坏的目的。那么应该如何判断到底哪个是病毒进度呢?标准的svchost.exe档案应该存在于“C:\Windows\system32”目录下,若果发现该档案出现在其他目录下就要小心了。2 C1 U- M h- p7 W
# M( f) {1 T& Q1 l: C5 T 提示:svchost.exe档案的呼叫路径可以通过“系统讯息→软体环境→正在执行任务”来检视; _2 i6 k& D. t2 W1 {
| 臬 |
|