好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

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#程序设计有所帮助。

dy("nrwz");

查看更多关于C#操作注册表的方法详解的详细内容...

  阅读:109次