当前位置: 首页 > 编程笔记 >

C#操作注册表的方法详解

廉学潞
2023-03-14
本文向大家介绍C#操作注册表的方法详解,包括了C#操作注册表的方法详解的使用技巧和注意事项,需要的朋友参考一下

本文实例讲述了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#程序设计有所帮助。

 类似资料:
  • 本文向大家介绍C#操作注册表的方法,包括了C#操作注册表的方法的使用技巧和注意事项,需要的朋友参考一下 C#操作注册表全攻略 相信每个人对注册表并不陌生,在运行里面输入“regedit”就可以打开注册表编辑器了。这东西对Windows系统来说可是比较重要的,也是病毒常常会光顾的地方,比如病毒和恶意软件常常会在注册表的启动项里面写入自己的启动键值来达到自启动的目的,有些病毒还会修改注册表里面来映像劫

  • 本文向大家介绍C#操作windows注册表的方法,包括了C#操作windows注册表的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了C#操作windows注册表的方法。分享给大家供大家参考。具体如下: 此代码演示了如何读取和写入注册表 读取注册表: 写入注册表: 希望本文所述对大家的C#程序设计有所帮助。

  • 本文向大家介绍C#获取注册表指定键值操作,包括了C#获取注册表指定键值操作的使用技巧和注意事项,需要的朋友参考一下 某些程序必须依赖指定运行环境。那么读取注册表来判断此电脑是否有执行环境是个很不错的办法。因为每个软件安装之后都会在注册表中注册对应的键值,并且有些键值是独一无二的。 那么首先就需要找到那个具体的独一无二的键值,以便程序在运行之前能够去读取以判断。 代码如下: 现在查找含有E:\Arc

  • 问题内容: 通常,当我创建Swing(或任何UI)应用程序时,菜单项和按钮上会显示各种动作。我通常创建一个动作注册表,并将动作存储在其中,然后在发生某些情况时,根据应用程序的状态在注册表中禁用/启用动作。尽管我对它的了解足够好,但我不会称自己为Swing的狂热开发者,但这是管理Action的非常典型的模式吗?还是有更标准的方法呢? 谢谢, 杰夫 问题答案: 杰夫,您的方法似乎是一种好方法。我做同样

  • 我想从公共repo的GitHub操作部署到GitHub包注册表。 我有一个工作流的yml文件: 我使用Leiningen构建项目并生成POM文件。然后我想使用Maven将工件部署到GitHub包注册表。 命令失败(我已将个人信息替换为): 我看到身份验证失败了。我也尝试过这一步,但效果相同: 我不想提供用户名/密码或令牌,因为这是一个公共存储库。有什么办法可以出版吗? 谢谢!

  • 本文向大家介绍C#实现读取注册表监控当前操作系统已安装软件变化的方法,包括了C#实现读取注册表监控当前操作系统已安装软件变化的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了C#实现读取注册表监控当前操作系统已安装软件变化的方法。分享给大家供大家参考。具体实现方法如下: 希望本文所述对大家的C#程序设计有所帮助。