|
马上注册,结识高手,享用更多资源,轻松玩转三维网社区。
您需要 登录 才可以下载或查看,没有帐号?注册
x
全面瞭解系统中 svchost.exe 档案 ? ?& c4 d u' G' m/ ^% r8 L% F
, H7 S# P2 U% u, Q笔者经常在一些反病毒论坛上浏览时,发现一些朋友对任务管理器中的svchost进度不甚瞭解,看见存在许多svchost进度就以为自己中了病毒,其实不然。
9 m# t1 Z+ d5 @% m" A" [! \
/ R4 Q& n6 n, F7 ^; ]& t. j svchost.exe是NT核心系统非常重要的档案,对于Win2000/XP来说,不可或缺。这些svchost进度提供很多系统服务,如:rpcss服务(remote procedure call)、dmserver服务(logical disk manager)、dhcp服务(dhcp client)等等。
K' ] {& T2 a# C7 l" y o- [' R4 e& {6 r, D0 O3 f2 O
若果要瞭解每个svchost进度到底提供了多少系统服务,可以在WinXP的指令提示符视窗中输入“tasklist /svc”指令来检视。5 v& S4 `* y) g
: z$ b$ l: t' u7 {3 ?
工作原理
7 k8 E2 Z- E2 O+ o! |4 V' @/ e7 G1 L' W
一般来说,Windows系统进度分为独立进度和共享进度两种。svchost.exe档案存在于%systemroot%\system32目录下,属于共享进度。( p3 r% B& r# x$ r! h
& L; b' P! D# I2 d2 [5 E8 b3 |* M
随着Windows系统服务不断增多,为了节省系统资源,微软把很多服务都做成共享模式,交由svchost进度来启动。但svchost进度只作为服务宿主,并不能实现任何服务功能,即它只能提供条件让其他服务在这里被启动,而它自己却不能给使用者提供任何服务。
# r, `. }! I: Z; a3 C5 i4 h% ?( s+ V O
这些服务是如何实现的呢?原来这些系统服务是以动态连结库(dll)形式实现的,它们把可执行程式指向svchost,由svchost呼叫相应服务的动态连结库来启动服务。
3 w2 X3 |5 N+ W/ a g
9 n" c$ p& w/ M5 b/ y9 H8 J 那svchost又怎么知道某个系统服务该呼叫哪个动态连结库呢?这是通过系统服务在注册表中设定的参数来实现的。
5 k' Q3 Q2 x2 m3 L/ \ t% H7 i" p; i* y
具体案例# v, J5 F; C4 r- [9 `
0 J8 o6 ~* h" T+ ?% t. [" Q6 z 下面以Remote Registry服务为例,来看看svchost进度是如何呼叫DLL档案的。在WinXP中,点击“开始→执行”,输入“services.msc”指令,会跳出服务对话框,然后开启“Remote Registry”属性对话框,可以看到Remote Registry服务的可执行档案的路径为“C:\Windows\System32\svchost -k LocalService”,这说明Remote Registry服务是依靠svchost呼叫“LocalService”参数来实现的,而参数的内容则是存放在系统注册表中的。
, {. L$ J: G7 }, c# p& ~* S' a: \ {/ P+ ^$ 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”服务注册表讯息,就能启动该服务了。0 F2 ~$ m3 t6 K* ?1 V
- D7 Z, Y7 T4 Z6 h9 h
也正是因为svchost的重要性,所以病毒、木马也想尽办法来利用它,企图利用它的特性来迷惑使用者,达到感染、入侵、破坏的目的。那么应该如何判断到底哪个是病毒进度呢?标准的svchost.exe档案应该存在于“C:\Windows\system32”目录下,若果发现该档案出现在其他目录下就要小心了。
; d0 t; p0 Q2 S/ L7 X9 t/ i% V8 d9 e5 B8 d/ W: v
提示:svchost.exe档案的呼叫路径可以通过“系统讯息→软体环境→正在执行任务”来检视4 q: N, N' k% Y; w5 D8 V4 c$ h7 [
| 臬 |
|