一、经典的启动——“启动文件夹
  单击开始程序,你会发现一个启动菜单,这就是最经典的Windows启动位置,右击启动菜单选择打开即可将其打开,如所示,其中的程序和快捷方式都会在系统启动时自动运行。最常见的启动位置如下:
  当前用户: <C:\Documents and Settings\用户名\「开始」菜单\程序\启动>
  所有用户: <C:\Documents and Settings\All Users\「开始」菜单\程序\启动>  

二、有名的启动——注册表启动项
  注册表是启动程序藏身之处最多的地方,主要有以下几项:
  1.Run
  Run键是病毒最青睐的自启动之所,该键位置是[HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Run][HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Run],其下的所有程序在每次启动登录时都会按顺序自动执行。
  还有一个不被注意的Run键,位于注册表[HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Policies\Explorer\Run][HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\Explorer\Run],也要仔细查看。
  2.RunOnce
  RunOnce位于[HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\RunOnce][HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\RunOnce]键,与Run不同的是,RunOnce下的程序仅会被自动执行一次。
  3.RunServicesOnce
  RunServicesOnce键位于[HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\RunServicesOnce][HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\RunServicesOnce]下,其中的程序会在系统加载时自动启动执行一次。
  4.RunServices
  RunServicesRunServicesOnce之后启动的程序,位于注册表[HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\RunServices][HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\RunServices]键。
  5.RunOnceEx
  该键是Windows XP/2003特有的自启动注册表项,位于[HKEY_CURRENT_USER\\SOFTWARE\Microsoft\Windows\CurrentVersion\RunOnceEx][HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\RunOnceEx]
  6.load
  [HKEY_CURRENT_USER\Software\Microsoft\WindowsNT\CurrentVersion\Windows]下的load键值的程序也可以自启动。
  7.Winlogon
  该键位于位于注册表[HKEY_CURRENT_USER\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon][HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon],注意下面的NotifyUserinitShell键值也会有自启动的程序,而且其键值可以用逗号分隔,从而实现登录的时候启动多个程序。
  8.其他注册表位置
  还有一些其他键值,经常会有一些程序在这里自动运行,如:[HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Policies\System\Shell]
[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\ShellServiceObjectDelayLoad]
[HKEY_CURRENT_USER\Software\Policies\Microsoft\Windows\System\Scripts]
[HKEY_LOCAL_MACHINE\Software\Policies\Microsoft\Windows\System\Scripts]

  小提示

  注册表的[HKEY_LOCAL_MACHINE][HKEY_CURRENT_USER]键的区别:前者对所有用户有效,后者只对当前用户有效。
  三、古老的启动——自动批处理文件
  从DOS时代过来的朋友肯定知道autoexec.bat(位于系统盘根目录)这个自动批处理文件,它会在电脑启动时自动运行,早期许多病毒就看中了它,使用deltreeformat等危险命令来破坏硬盘数据。如“C盘杀手就是用一句“deltree /y c:\*.*”命令,让电脑一启动就自动删除C盘所有文件,害人无数。

  小提示

  ★在Windows 98中,Autoexec.bat还有一个哥们——Winstart.bat文件,winstart.bat位于Windows文件夹,也会在启动时自动执行。
  ★在Windows Me/2000/XP中,上述两个批处理文件默认都不会被执行。
  四、常用的启动——系统配置文件
  在Windows的配置文件(包括Win.iniSystem.iniwininit.ini文件)也会加载一些自动运行的程序。
  1.Win.ini文件
  使用记事本打开Win.ini文件,在[windows]段下的“Run=”“LOAD=”语句后面就可以直接加可执行程序,只要程序名称及路径写在后面即可。

  小提示
  “load=”后面的程序在自启动后最小化运行,而“run=”后程序则会正常运行。
  2.System.ini文件
  使用记事本打开System.ini文件,找到[boot]段下“shell=”语句,该语句默认为“shell=Explorer.exe”,启动的时候运行Windows外壳程序explorer.exe。病毒可不客气,如妖之吻病毒干脆把它改成“shell=c:\yzw.exe”,如果你强行删除妖之吻病毒程序yzw.exeWindows就会提示报错,让你重装Windows,吓人不?也有客气一点的病毒,如将该句变成“shell=Explorer.exe 其他程序名,看到这样的情况,后面的其他程序名一定是病毒程序如所示。
  3.wininit.ini
  wininit.ini文件是很容易被许多电脑用户忽视的系统配置文件,因为该文件在Windows启动时自动执后会被自动删除,这就是说该文件中的命令只会自动执行一次。该配置文件主要由软件的安装程序生成,对那些在Windows图形界面启动后就不能进行删除、更新和重命名的文件进行操作。若其被病毒写上危险命令,那么后果与“C盘杀手无异。
  小提示
  ★如果不知道它们存放的位置,按F3键打开搜索对话框进行搜索;
  ★单击开始运行,输入sysedit回车,打开系统配置编辑程序,如图2所示,在这里也可以方便的对上述文件进行查看与修改。

五、智能的启动——/关机/登录/注销脚本
  在Windows 2000/XP中,单击开始运行,输入gpedit.msc回车可以打开组策略编辑器,在左侧窗格展开本地计算机策略用户配置管理模板系统登录,然后在右窗格中双击在用户登录时运行这些程序,单击显示按钮,在登录时运行的项目下就显示了自启动的程序。

六、定时的启动——任务计划
  在默认情况下,任务计划程序随Windows一起启动并在后台运行。如果把某个程序添加到计划任务文件夹,并将计划任务设置为系统启动时登录时,这样也可以实现程序自启动。通过计划任务加载的程序一般会在任务栏系统托盘区里有它们的图标。大家也可以双击控制面板中的计划任务图标查看其中的项目。

  小提示
  任务计划也是一个特殊的系统文件夹,单击开始程序附件系统工具任务计划即可打开该文件夹,从而方便进行查看和管理。

在以下注册表项中找到下面的位置:
HKEY_LOCAL_MACHINE\Software\Microsoft\Windows NT\CurrentVersion\Windows\AppInit_DLLs
其中指定的所有 DLL 都会加载到每个 Microsoft 会话上运行的基于 Windows 的应用程序中。
也就是说所有GUI程序都会被挂上该动态库。

注册表的服务启动项 Start类型详解
HKLM\SYSTEM\CurrentControlSet\services\
下的服务项。不论有没有在services.msc服务管理控制台中显示,在注册表中都有一个Start项。

Start
的可能取值有以下几种,分别代表了不同的服务启动类型
Start=0 boot
Start=1 system
Start=2
自动
Start=3
手动
Start=4
禁用

对应于SC命令行来设置服务启动类型
SC config “SERNER_NAME” START= {BOOT|SYSTEM|AUTO|DEMAND|DISABLED|delayed-auto}
接下来启动服务
SC Start “SERVER_NAME”
指定服务的起始类型。

说明
boot
由启动引导程序加载的设备驱动器。
system
在核心初始化过程中启动的设备驱动器。
auto
每次计算机重新启动时,甚至没有人登录计算机时,都能自动开始的服务。
demand
必须手动启动的服务。如果没有指定“start=”,这就默认值。
disabled
不能启动的服务。要启动一个禁用的服务,把启动类型更改为其他值
delayed-auto
自动延时启动。此时start=2并且DelayedAutostart=1 Start为其它值时,DelayedAutostart1不起作用。
服务管理器不能及时更新delayedautostart的值