QQ登录

只需一步,快速开始

登录 | 注册 | 找回密码

三维网

 找回密码
 注册

QQ登录

只需一步,快速开始

展开

通知     

全站
10天前
查看: 1354|回复: 0
收起左侧

[分享] 全面瞭解系統中 svchost.exe 文件

[复制链接]
发表于 2007-2-18 02:41:08 | 显示全部楼层 |阅读模式 来自: 中国台湾

马上注册,结识高手,享用更多资源,轻松玩转三维网社区。

您需要 登录 才可以下载或查看,没有帐号?注册

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 {
发表回复
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Licensed Copyright © 2016-2020 http://www.3dportal.cn/ All Rights Reserved 京 ICP备13008828号

小黑屋|手机版|Archiver|三维网 ( 京ICP备2023026364号-1 )

快速回复 返回顶部 返回列表