注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

信息 灵感 创新

I? =Information,Inspiration,Innovation

 
 
 

日志

 
 
关于我

we are 5. Mathematics, Computation, Programming, Engineering, and Making fun of life.

网易考拉推荐

利用C#操作注册表  

2010-12-04 18:52:18|  分类: C# & .NET |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

注册表项是注册表中的基本组织单位,好比是 Windows 资源管理器中的文件夹。每个具体的注册表项都可以有子项,就像文件夹下可以有子文件夹一样。只要用户具有相应的权限,且注册表项不是基项或基项的下一级项,就可以删除该注册表项。每个注册表项也可带有与其相关联的多个值(一个值就好比是一个文件),它们用于存储信息,例如,有关计算机上安装的应用程序的信息。每个值存储特定的信息,可按需要对其进行检索或更新。例如XXX可以为你的软件创建一个 RegistryKey(在项 HKEY_LOCAL_MACHINE\Software 下),然后为您的公司创建的每个应用程序创建一个子项。每个子项保存特定于该应用程序的信息,如颜色设置、屏幕位置和大小或者可识别的文件扩展名等。

注意,存储在注册表中的信息可被其他应用程序和用户访问和修改,因此不要用注册表存储安全、敏感的数据或关键的应用程序信息。

对于注册表的操作,主要包括注册表项的创建,打开与删除,键值的创建(修改),读取和删除,以及判断注册表项、键值是否存在。

首先需要引入的命名空间是:

using Microsoft.Win32;

该命名空间下的类RegistryKey表示 Windows 注册表中的项级节点,此类是注册表封装。用于定位到注册表最开头的分支,另外一个类是Registry,提供表示 Windows 注册表中的根项的 RegistryKey 对象,并提供访问项/值对的 static 方法。

Registry公共字段

对应注册表基项分支

说明

ClassesRoot

HKEY_CLASSES_ROOT

定义文档的类型(或类)以及与那些类型关联的属性。

CurrentUser

HKEY_CURRENT_USER

包含有关当前用户首选项的信息

LocalMachine

HKEY_LOCAL_MACHINE

包含本地计算机的配置数据

Users

HKEY_USERS

包含有关默认用户配置的信息

CurrentConfig

HKEY_CURRENT_CONFIG

包含有关非用户特定的硬件的配置信息

DynData

HKEY_DYN_DATA

包含动态注册表数据

PerformanceData

HKEY_PERFORMANCE_DATA

包含软件组件的性能信息

一、项的创建、打开和删除

1.创建项

例如在HKEY_LOCAL_MACHINE基项下的SOFTWARE项下创建一个新的项YourSoftware,可以采用如下代码:

RegistryKey lm = Registry.LocalMachine;

//对应HKEY_LOCAL_MACHINE基项分支

RegistryKey software = lm.OpenSubKey("SOFTWARE", true);

//打开Software

RegistryKey product = software.CreateSubKey("YourSoftware");

关于OpenSubKey的第二个参数将在打开项中做详细介绍

2.打开项

其实在创建项的时候已经使用过了打开项的代码:

RegistryKey lm = Registry.LocalMachine;

//对应HKEY_LOCAL_MACHINE基项分支

RegistryKey software = lm.OpenSubKey("SOFTWARE", true);

//打开Software

lm.Close();

注意OpenSubKey的第二个参数表示writable,即是否可写入,如果需要创建或者删除就应该使用true,一般读取用false。另外,如果请求的项不存在,则返回空引用,而不是引发异常。最后,关闭项就是Close()方法。

这可以用下面的代码测试:

RegistryKey lm = Registry.LocalMachine;

RegistryKey s;

try

{

    s = lm.OpenSubKey("asdfaf", true);

    //试图打开不存在的项asdfaf

    if (s == null)

        Console.WriteLine("return value is null!");

}

catch (Exception)

{

    Console.WriteLine("I catch an exception!");

}

运行的结果是没有捕捉到任何异常,而s确实为null

3.删除项

必须具有适当权限才能删除子项及其目录树。

RegistryKey lm = Registry.LocalMachine;

//对应HKEY_LOCAL_MACHINE基项分支

RegistryKey software = lm.OpenSubKey("SOFTWARE", true);

//打开Software

try

{

    software.DeleteSubKeyTree("YourSoftware");

    //将移除目录树中该项下的所有项和键

}

catch (Exception)

{

    Console.WriteLine("Delete Subkey Failed");

}

lm.Close();

注意:这种删除将会将指定项下所有的项和键,并且删除将不提供任何警告,如果想仅在子项没有子级子项(仅包括键)时才删除该子项,应使用 DeleteSubKey 方法。

二、键值的创建(修改)、读取和删除

1.创建和设置键值

下列代码块会在HKEY_LOCAL_MACHINE基项下的SOFTWARE项下创建一个新的项YourSoftware,并在下面创建一个名为Version的键,其键值为1.23,如果该键已存在,将修改键值为1.23

RegistryKey lm = Registry.LocalMachine;

//对应HKEY_LOCAL_MACHINE基项分支

RegistryKey software = lm.OpenSubKey("SOFTWARE",true);

//打开Software

RegistryKey product = software.CreateSubKey("YourSoftware");

//SOFTWARE项下创建"YourSoftware"的项

product.SetValue("Version", "1.23");

//在该项下创建一个键位Version,键值为.23          

lm.Close();//关闭

另外,SetValue方法已重载,第三个参数RegistryValueKind是一个枚举类型,此枚举在 .NET Framework 2.0 版中是新增的,它用来指定在注册表中存储值时所用的数据类型,或标识注册表中某个值的数据类型。例如在YourSoftware项下增加一个名称为:MyValue , 类型为REG_DWORD 的键,数值为十进制的147,可以这样使用SetValue

product.SetValue("MyValue", 147, RegistryValueKind.DWord);

RegistryValueKind 枚举成员

成员名称

对应注册表数据类型

说明

Binary

REG_BINARY

指定任意格式的二进制数据

DWord

REG_DWORD

指定一个32位二进制数

ExpandString

REG_EXPAND_SZ

指定一个以 NULL 结尾的字符串,该字符串中包含对环境变量(如 %PATH%,当值被检索时,就会展开)的未展开的引用

MultiString

REG_MULTI_SZ

指定一个以NULL结尾的字符串数组,以两个空字符结束

QWord

REG_QWORD

指定一个64位二进制数

String

REG_SZ

指定一个以Null结尾的字符串

Unknown

指示一个不受支持的注册表数据类型

2.读取键值

例如想读取上面的键Version的值,可以采用以下方法:

RegistryKey lm = Registry.LocalMachine;

//对应HKEY_LOCAL_MACHINE基项分支

RegistryKey software = lm.OpenSubKey("SOFTWARE",false);

//打开Software

RegistryKey product = software.OpenSubKey("YourSoftware", false);

Console.WriteLine(product.GetValue("Version").ToString());

//在该项下读取键Version的键值并显示

显然得到的结果为1.23,由于这里只是读取键值,所以OpenSubKey的第二个参数用false比较好,可以避免对键值的修改。另外,GetValue用于检索注册表项中的指定名称关联的值。如果在指定的项中未找到该键,则返回您提供的默认值;或者,如果指定的项不存在,则返回空引用。

3.删除键值

还是以上面的Version为例:

RegistryKey lm = Registry.LocalMachine;

//对应HKEY_LOCAL_MACHINE基项分支

RegistryKey software = lm.OpenSubKey("SOFTWARE", true);

//打开Software

RegistryKey product = software.OpenSubKey("YourSoftware", true);

product.DeleteValue("Version");

//删除Version

三、判断项和键是否存在

1.判断项是否存在

前面在打开项的时候使用了方法OpenSubKey,调用该方法如果请求的项不存在,则返回空引用,而不是引发异常。这个就可以作为我们判断项是否存在的依据:

RegistryKey lm = Registry.LocalMachine;

RegistryKey s;

 s = lm.OpenSubKey("asdfaf", true);

//试图打开不存在的项asdfaf

if (s == null)

Console.WriteLine("该项不存在");

如果HKEY_LOCAL_MACHINE\SOFTWARE下没有这个项的话,控制台将会输出该项不存在的信息。

2.判断键是否存在

类似前面判断项的做法,在使用GetValue方法时,如果键不存在,得到的也是一个空引用,例如只是想判断Version键是否存在,代码如下:

RegistryKey lm = Registry.LocalMachine;

//对应HKEY_LOCAL_MACHINE基项分支

RegistryKey software = lm.OpenSubKey("SOFTWARE", false);

//打开Software

RegistryKey product = software.OpenSubKey("YourSoftware", false);

if (product.GetValue("Version654") == null)

    Console.WriteLine("该键不存在");

 

 PDF格式的文档上传到百度文库中了,需要的朋友可以到这里下载,不过需要注册百度账号……
  评论这张
 
阅读(3956)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2016