dotnet 利用 Windows 注册表实现开机自动启动
本文将演示写入 HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Run 注册表路线,实现应用程序开机自动启动
核心代码如下
static class BoostHelper
{
/// <summary>
/// 添加到启动项,添加到注册表,仅限 Windows 系统,写入到 HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Run 里,实现开机启动
/// </summary>
/// <param name="name"></param>
/// <param name="exePath"></param>
/// <param name="arguments"></param>
[SupportedOSPlatform("Windows")]
public static void AddStartup(string name, string exePath, params string[] arguments)
{
// 添加开机启动
// 写入到 HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Run 里
var runKey = Microsoft.Win32.Registry.CurrentUser.OpenSubKey("Software\\Microsoft\\Windows\\CurrentVersion\\Run", true);
if (runKey is not null)
{
var valueStringBuilder = new StringBuilder();
valueStringBuilder.Append($"\"{exePath}\"");
foreach (var argument in arguments)
{
valueStringBuilder.Append($" \"{argument}\"");
}
string value = valueStringBuilder.ToString();
var existingValue = runKey.GetValue(name) as string;
if (existingValue != value)
{
runKey.SetValue(name, value);
//LogMessage($"已设置开机启动,路径:{exePath}");
}
else
{
//LogMessage($"已设置过开机启动,路径:{exePath}");
}
}
}
[SupportedOSPlatform("Windows")]
public static void RemoveStartup(string name)
{
var runKey = Microsoft.Win32.Registry.CurrentUser.OpenSubKey("Software\\Microsoft\\Windows\\CurrentVersion\\Run", true);
if (runKey is not null)
{
runKey.DeleteValue(name, false);
//LogMessage($"已删除开机启动,路径:{exePath}");
}
}
}
调用 BoostHelper 方法的示例代码如下
BoostHelper.AddStartup("Test", Environment.ProcessPath!);
传入的 AddStartup 的 name 参数表示一个注册表项名,合理的命名即可,没有特殊含义。同名的 name 将会相互覆盖,利用此覆盖机制即可实现更新启动路径的功能。删除时,就是直接删除对应的 name 项即可
写入之后,将在开机之后,用户登录之后,进入桌面之后启动程序。启动时使用当前用户的账户权限,且启动时机是延迟启动,相对来说比较友好,不会卡开机。这是比较常用的开机自启的注册表
在 Windows 上,还有很多其他注册表项可以用来添加开机自启,其差别的核心维度就是由什么、在什么时机启动
常见的添加开机自启的注册表项如下
- 当前用户专有的启动文件夹:
%AppData%\Microsoft\Windows\Start Menu\Programs - 所有用户有效的启动文件夹:
%ProgramData%\Microsoft\Windows\Start Menu\Programs - Userinit注册键
- 注册表地址:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon - 通常该注册表下面有一个
C:\Windows\system32\userinit.exe,值,但这个键值是允许用逗号来分隔多个程序的,比如 C:\Windows\system32\userinit.exe,C:\lindexi.exe(举例)
- 注册表地址:
- Explorer\Run注册键
- 当前用户的注册表地址:
HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Policies\Explorer\Run - 机器级的注册表地址:
HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Policies\Explorer\Run
- 当前用户的注册表地址:
- RunServicesOnce注册键
- 当前用户的注册表地址:
HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\RunServicesOnce - 机器级的注册表地址:
HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\RunServicesOnce - RunServicesOnce注册键是用来启动服务的,启动时间是在用户登录之前,而且是先于其它通过注册键启动的程序
- 当前用户的注册表地址:
- RunServices注册键
- 当前用户的注册表地址:
HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\RunServices - 机器级的注册表地址:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\RunServices - RunServices注册键指定的程序紧接RunServicesOnce指定的程序之后运行,启动时间也是在用户登录之前
- 当前用户的注册表地址:
- RunOnce注册键
- 注册表地址:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\RunOnceHKEY_LOCAL_MACHINE\Software\WOW6432Node\Microsoft\Windows\CurrentVersion\RunOnceHKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\RunOnce
- HKEY_LOCAL_MACHINE下面的RunOnce注册键会在用户登录之后立即运行程序,运行的时机是在其它Run键指定的程序之前
- HKEY_CURRENT_USER则会启动比较慢,它会在操作系统处理其他Run键以及“启动”文件夹的内容之后运行
- 注册表地址:
- Run注册键
- 注册表地址:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\RunHKEY_LOCAL_MACHINE\Software\WOW6432Node\Microsoft\Windows\CurrentVersion\RunHKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Run
- Run是自动运行程序最常用的注册表。会先执行HKEY_LOCAL_MACHINE下的Run注册键内容,再执行HKEY_CURRENT_USER下的Run注册键内容,但两者都是在处理“启动文件夹”之前
- 注册表地址:
除了本文记录的写注册表方法之外,还可以在启动文件夹存放快捷方式实现开机自启,详细请参阅 WPF 开发自动开机启动程序
本文代码放在 github 和 gitee 上,可以使用如下命令行拉取代码。我整个代码仓库比较庞大,使用以下命令行可以进行部分拉取,拉取速度比较快
先创建一个空文件夹,接着使用命令行 cd 命令进入此空文件夹,在命令行里面输入以下代码,即可获取到本文的代码
git init
git remote add origin https://gitee.com/lindexi/lindexi_gd.git
git pull origin e2a02a9aaa2148cc580cdbc91b92a5970d4b470f
以上使用的是国内的 gitee 的源,如果 gitee 不能访问,请替换为 github 的源。请在命令行继续输入以下代码,将 gitee 源换成 github 源进行拉取代码。如果依然拉取不到代码,可以发邮件向我要代码
git remote remove origin
git remote add origin https://github.com/lindexi/lindexi_gd.git
git pull origin e2a02a9aaa2148cc580cdbc91b92a5970d4b470f
获取代码之后,进入 Workbench/QeyeqawkayqaiWhonirikaywi 文件夹,即可获取到源代码
博客园博客只做备份,博客发布就不再更新,如果想看最新博客,请访问 https://blog.lindexi.com/
如图片看不见,请在浏览器开启不安全http内容兼容

本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。欢迎转载、使用、重新发布,但务必保留文章署名[林德熙](https://www.cnblogs.com/lindexi)(包含链接:https://www.cnblogs.com/lindexi ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请与我[联系](mailto:lindexi_gd@163.com)。

浙公网安备 33010602011771号