C#操作注册表的方法详解
作者:方倍 发布时间:2022-03-09 14:57:14
本文实例讲述了C#操作注册表的方法。分享给大家供大家参考,具体如下:
下面我们就来用.NET下托管语言C#注册表操作,主要内容包括:注册表项的创建,打开与删除、键值的创建(设置值、修改),读取和删除、判断注册表项是否存在、判断键值是否存在。
准备工作:
1. 要操作注册表,我们必须要引入必要的命名空间:
using Microsoft.Win32;
在这个命名空间里面包含了许多注册表相关的类,足够我们使用了~~
2. 命名空间里面提供了一个类:RegistryKey 利用它我们可以定位到注册表最开头的分支:
ClassesRoot,CurrentUser,Users,LocalMachine,CurrentConfig
如:
RegistryKey key = Registry.LocalMachine;
3. 在操作的过程中涉及到子分支,要用\\进行深入,单个\会报错!
4. 最后要调用RegistryKey对象的Close()关闭对注册表的修改~~~
5. 以下我们的例子都是在LocalMachine分支下,请注意。
一、C#注册表项的创建,打开与删除
1. 创建
创建注册表项主要用到RegistryKey 的CreateSubKey()方法。如:
RegistryKey key = Registry.LocalMachine;
RegistryKey software = key.CreateSubKey("software\\test");
//在HKEY_LOCAL_MACHINE\SOFTWARE下新建名为test的注册表项。如果已经存在则不影响!
2. 打开
打开注册表项主要用到RegistryKey 的OpenSubKey()方法。如:
注意,如果该注册表项不存在,这调用这个方法会抛出异常
RegistryKey key = Registry.LocalMachine;
RegistryKey software = key.OpenSubKey("software\\test",true);
//注意该方法后面还可以有一个布尔型的参数,true表示可以写入。
3. 删除
删除注册表项主要用到RegistryKey 的DeleteSubKey()方法。如:
RegistryKey key = Registry.LocalMachine;
key.DeleteSubKey("software\\test",true); //该方法无返回值,直接调用即可
key.Close();
注意,如果该注册表项不存在,这调用这个方法会抛出异常
二、键值的创建(设置值、修改),读取和删除
1. 创建(设置值、修改)
对键值的创建修改等操作主要用到RegistryKey 的SetValue()方法
RegistryKey key = Registry.LocalMachine;
RegistryKey software = key.OpenSubKey("software\\test",true); //该项必须已存在
software.SetValue("test", "脚本之家");
//在HKEY_LOCAL_MACHINE\SOFTWARE\test下创建一个名为“test”,值为“脚本之家”的键值。如果该键值原本已经存在,则会修改替换原来的键值,如果不存在则是创建该键值。
// 注意:SetValue()还有第三个参数,主要是用于设置键值的类型,如:字符串,二进制,Dword等等~~默认是字符串。如:
// software.SetValue("test", "0", RegistryValueKind.DWord); //二进制信息
Key.Close();
2. 读取
string info = "";
RegistryKey Key;
Key = Registry.LocalMachine;
myreg = Key.OpenSubKey("software\\test");
// myreg = Key.OpenSubKey("software\\test",true);
info = myreg.GetValue("test").ToString();
myreg.Close();
info结果为:脚本之家
3:删除
RegistryKey delKey = Registry.LocalMachine.OpenSubKey("Software\\test", true);
delKey.DeleteValue("test");
delKey.Close();
细心的读者可能发现了第二个例子中OpenSubKey()方法参数与其他例子的不同。
如果你要修改键值,包括创建、设置、删除键值等都要在方法后面加个布尔参数,设置为true,表示可写可改;如果仅仅只是读取键值可以不加,此时可写关闭,你不能再往里写值(当然,你要加也可以true)!
还有读者提到读写默认键值的问题,主要在设置、读取的方法中将键名置空则就是对默认键值的操作。
如:
software.SetValue("", "脚本之家"); // 在HKEY_LOCAL_MACHINE\SOFTWARE\test修改默认键值的值为“脚本之家”。读取类似!
另外,默认的键值是不能删除的,所以不要用DeleteValue()方法去删除,会抛出异常的!
三、判断注册表项是否存在
private bool IsRegeditItemExist()
{
string [] subkeyNames;
RegistryKey hkml = Registry.LocalMachine;
RegistryKey software = hkml.OpenSubKey("SOFTWARE");
//RegistryKey software = hkml.OpenSubKey("SOFTWARE", true);
subkeyNames = software.GetSubKeyNames();
//取得该项下所有子项的名称的序列,并传递给预定的数组中
foreach (string keyName in subkeyNames)
//遍历整个数组
{
if (keyName == "test")
//判断子项的名称
{
hkml.Close();
return true ;
}
}
hkml.Close();
return false;
}
四、判断键值是否存在
private bool IsRegeditKeyExit()
{
string[] subkeyNames;
RegistryKey hkml = Registry.LocalMachine;
RegistryKey software = hkml.OpenSubKey("SOFTWARE\\test");
//RegistryKey software = hkml.OpenSubKey("SOFTWARE\\test", true);
subkeyNames = software.GetValueNames();
//取得该项下所有键值的名称的序列,并传递给预定的数组中
foreach (string keyName in subkeyNames)
{
if (keyName == "test") //判断键值的名称
{
hkml.Close();
return true;
}
}
hkml.Close();
return false;
}
补充:x32软件在x64系统下操作注册表,会自动转向到Wow6432Node,为了控制不转向,使用以下代码:
/// <summary>
/// 获得根节点的句柄,常数是固定的
/// </summary>
/// <param name="hive"></param>
/// <returns></returns>
public static IntPtr GetHiveHandle(RegistryHive hive)
{
IntPtr preexistingHandle = IntPtr.Zero;
IntPtr HKEY_CLASSES_ROOT = new IntPtr(-2147483648);
IntPtr HKEY_CURRENT_USER = new IntPtr(-2147483647);
IntPtr HKEY_LOCAL_MACHINE = new IntPtr(-2147483646);
IntPtr HKEY_USERS = new IntPtr(-2147483645);
IntPtr HKEY_PERFORMANCE_DATA = new IntPtr(-2147483644);
IntPtr HKEY_CURRENT_CONFIG = new IntPtr(-2147483643);
IntPtr HKEY_DYN_DATA = new IntPtr(-2147483642);
switch (hive)
{
case RegistryHive.ClassesRoot: preexistingHandle = HKEY_CLASSES_ROOT; break;
case RegistryHive.CurrentUser: preexistingHandle = HKEY_CURRENT_USER; break;
case RegistryHive.LocalMachine: preexistingHandle = HKEY_LOCAL_MACHINE; break;
case RegistryHive.Users: preexistingHandle = HKEY_USERS; break;
case RegistryHive.PerformanceData: preexistingHandle = HKEY_PERFORMANCE_DATA; break;
case RegistryHive.CurrentConfig: preexistingHandle = HKEY_CURRENT_CONFIG; break;
case RegistryHive.DynData: preexistingHandle = HKEY_DYN_DATA; break;
}
return preexistingHandle;
}
使用:
/// <summary>
/// 操作注册表
/// </summary>
/// <param name="hive">根级别的名称</param>
/// <param name="path">不包括根级别的名称</param>
/// <param name="parameters">项/(值/值类型) 参数</param>
/// <param name="view">注册表视图</param>
[RegistryPermissionAttribute(SecurityAction.LinkDemand, Unrestricted = true)]
public static void OperateReg(RegistryHive hive, string path, Dictionary<string, string[]> parameters, RegistryView view)
{
SafeRegistryHandle handle = new SafeRegistryHandle(GetHiveHandle(hive), true);
RegistryKey r = RegistryKey.FromHandle(handle, view).CreateSubKey(path, RegistryKeyPermissionCheck.ReadWriteSubTree);
//一般情况是使用如下代码:
//RegistryKey rk = Registry.LocalMachine.CreateSubKey(path);
if (parameters == null && parameters.Count <= 0)
return;
List<string> keys = parameters.Keys.ToList();
for (int i = 0; i < parameters.Count; i++)
{ //string to RegistryValueKind
RegistryValueKind rv = (RegistryValueKind)Enum.Parse(typeof(RegistryValueKind), parameters[keys[i]][1].ToString(), true);
r.SetValue(keys[i], parameters[keys[i]][0], rv);
}
}
例子:
public static void RegisterScreenCapture(string targetDir, string guid, bool is64BitLync)
{
if (string.IsNullOrEmpty(guid))
guid = "{541a4dc3-50dc-4b4f-a38d-0ed1d360ca6b}";
Dictionary<string, string[]> paraCapture = new Dictionary<string, string[]>();
paraCapture["Name"] = new string[] { "ScreenCapture", RegistryValueKind.String.ToString() };
paraCapture["Path"] = new string[] { string.Format("{0}IcoLync.ScreenCapture.exe", targetDir), RegistryValueKind.String.ToString() };
paraCapture["Extensiblemenu"] = new string[] { "ConversationWindowActions", RegistryValueKind.String.ToString() };
paraCapture["SessionType"] = new string[] { "0", RegistryValueKind.DWord.ToString() };
RegistryView rv;
if (is64BitLync)
rv = RegistryView.Registry64;
else
rv = RegistryView.Default;
OperateReg(RegistryHive.LocalMachine, string.Format(@"SOFTWARE\Microsoft\Office\15.0\Lync\SessionManager\Apps\{0}", guid), paraCapture, rv);
}
刚才经过测试,不需要GetHiveHandl()也行(我也不知道什么需要);
OperateReg()方法中一二行代码改为
RegistryKey r = RegistryKey.OpenBaseKey(hive, view).CreateSubKey(path, RegistryKeyPermissionCheck.ReadWriteSubTree);
希望本文所述对大家C#程序设计有所帮助。
猜你喜欢
- 目前html5发展非常迅速,很多native app都会嵌入到网页中,以此来适用多变的市场需求。但是android的webview默认支持的
- 本文实例为大家分享了java实现打印正三角的具体代码,供大家参考,具体内容如下代码:package BasicType;/** * 封装一个
- 1. 概述:将一个具体类的实例化交给一个静态工厂方法来执行,它不属于GOF的23种设计模式,但现实中却经常会用到2. 模式中的角色2.1 工
- /** * 朴素字符串算法通过两层循环来寻找子串, * 好像是一个包含模式的“模板”沿待查文本滑动。 * 算法的思想是:从主串S的第p
- 动态数据源在很多具体应用场景的时候,我们需要用到动态数据源的情况,比如多租户的场景,系统登录时需要根据用户信息切换到用户对应的数据库。又比如
- 本文实例为大家分享了unity使用socket实现聊天室功能的具体代码,供大家参考,具体内容如下示例:什么是Socket:Socket(套接
- rpc远程调用可能存在的问题超时的问题。安全的问题。服务与服务之间URL地址管理。在我们的微服务架构通讯,服务之间依赖关系非常大,如果通过传
- 多环境开发我们平常都是在自己的开发环境进行开发,当开发完成后,需要把开发的功能部署到测试环境供测试人员进行测试使用,等测试人员测试通过后,我
- 场景:最新的leakCanary2.8.1:debugImplementation 'com.squareup.leakcanary
- Java数字格式类以下两个类可用于格式化和解析数字:java.text.NumberFormatjava.text.DecimalForma
- 音乐播放需要调用service,在此,只是简单梳理播放流程。public class PlayMusicService extends Se
- 由于最近项目忙,博客一直没有时间更新,今天有点时间就连续更新两篇吧,过过瘾。这篇图片拖拽缩放也是我在项目中用到的,今天整理一下,将源码奉献给
- 一、利用Web服务中的JavaScriptSerializer 类System.Web.Script.Serialization空间,位于S
- 一、对AOP的初印象首先先给出一段比较专业的术语(来自百度):在软件业,AOP为Aspect Oriented Programming的缩写
- 该篇文章篇幅很长,大概的思路如下 maven的介绍,初步
- 使用Spring3 实现用户登录以及权限认证这里我就简单介绍一下,我在实现的时候处理的一些主要的实现。1.用户登录 <form act
- 单一职责原则:一个类,只有一个引起它变化的原因。为什么需要单一职责原则?如果一个类有多个原因要去修改它,那么修改一个功能时,可能会让其他功能
- 目录概述事件监听的结构Publisher,Event和Listener的关系事件发布者监听者总结概述ApplicationEvent以及Li
- 1.launch启动协程fun main() = runBlocking { launch { &
- 目录关于日志级别为什么选用log4j2排除 spring-boot 自带的 logback 依赖添加 log4j2 依赖配置文件节点解析根节