虽然微软已经推出Windows家族的Active Directory的很多优点,但注册表依旧是Windows机器的活力源泉。注册表用于存储软件安装数据,正如存储文件相关信息和特定用户信息一样。过去,对注册表的操作往往与使用Windows API有关。对于当前的多数情况,.NET框架能够通过提供更加轻易的注册表访问而简化了注册表的操作过程。
注册表
注册表作为一台计算机程序和Windows信息的仓库中心,其结构组织为分等级形式,而这一分等级形式是以一个具有存储信息的单元的逻辑顺序为基础。
当在注册表中存储信息时,根据要存储的信息类型选择合适的位置。Windows包含一个名为注册表编辑器Registry Editor (regedit.exe)的工具,你可以使用这一工具来查看或者操作注册表数据。当浏览注册表时,你将注重到键的等级种类以及它们的值。(一句警告的话:在编辑注册表数据的时候一定格外小心,因为你会有可能影响到操作系统或者程序。在保存任何注册表编辑更改之前,请确保做一个校验的备份。)
一个注册表具有以下最高等级的键值:
KKEY_CLASSES_ROOT:这一键包括文件扩展相关信息和COM类注册信息,比如PRogIDs, CLSIDs, 以及IIDs。其主要目的是使系统兼容于16位Windows的注册表。
HKEY_CURRENT_USER:这一键包含与HKEY_USERS中的安全特性标识符列举的信息类似。HKEY_CURRENT_USER的任何改变都立即引起HKEY_USERS的改变,反之亦然。
HKEY_LOCAL_MACHINE:这一键存储计算机的系统信息,并包含从软件设置到网络及硬件配置的所有信息。这些配置与用户无关,因为这些设置必须适用于使用机器的所有用户。
HKEY_USERS:这一键保存使用操作系统和程序的所有用户。
HKEY_CURRENT_CONFIG:这一键针对于存储在HKEY_LOCAL_MACHINE\Config\000x键的设置集合中的当前计算机配置,而HKEY_LOCAL_MACHINE\Config\000x键包含着当前硬件配置信息(x表示配置数目)。
这些都是微软操作系统中的基本的键。你可以使用你最喜爱的.NET语言来操作注册表。
Windows.Win32名称空间
.NET Windows.Win32名称空间提供了操作一个Windows注册表的所有信息,以下是它用于操作注册表的类:
Registry:提供查找Windows机器中注册表的一套标准根部键。
RegistryKey:代表Windows注册表的一个键等级节点。
注册表类提供了能够对不同键的访问:
CurrentUser: 操作HKEY_CURRENT_USER键
LocalMachine: 操作HKEY_LOCAL_MACHINE键
ClassesRoot: 操作HKEY_CLASSES_ROOT键
Users: 操作HKEY_USERS键
CurrentConfig: 操作HKEY_CURRENT_CONFIG键
PerformanceData:提供软件组件的性能信息
DynData: 处理动态数据
例如,你可以使用以下代码来访问HKEY_CURRENT_USER键:
首先,代码通过注册表类将一个RegistryKey对象初始化LocalMachine键。接着,调用DisplayKeys函数,它显示所有的子键和相关的值,并使用递归方式来调用每一子键,通过标准输出方式来显示结果。以下是使用VB.NET的相同代码:
保存键的值
除了可以读取由其它程序建立的数据,注册表也可以作为信息保存的仓库。CreateSubKey键和RegistryKey类的SetValue方法可以完成这一过程。以下的VB.NET代码在HKEY_CURRENT_USER的Software子键中建立一个子键,并赋予一个值:
这里是C#中相同的程序段:
你可以很轻易地读取这些被保存的值:
这些键值以纯文本格式被保存,所以使用这一机器的任何人都可以很轻易地访问到这些数据。基于此,一些敏感数据不应该保存在注册表中,或者在保存之前应该先加密。当加密的时候,键值也应该被保存以致数据在必要时可以很轻易地被加密。这一方法经常用于安全地保存数据库连接字符串。