C#操作注册表全攻略

相信每个人对注册表并不陌生,在运行里面输入“regedit”就可以打开注册表编辑器了。这东西对Windows系统来说可是比较重要的,也是病毒常常会光顾的地方,比如病毒和恶意软件常常会在注册表的启动项里面写入自己的启动键值来达到自启动的目的,有些病毒还会修改注册表里面来映像劫持杀毒软件,这是破坏系统的第一步。同时,大多软件(软件的序列号和信息)和硬件信息、系统信息、安全模式等等设置都保存在这里,因此系统的健康在很大程度上要依赖注册表的健康。

作为编程开发人员,我们有必要了解注册表并学会操作注册表。下面我们就来用.NET下托管语言C#操作注册表,主要内容包括:注册表项的创建,打开与删除、键值的创建(设置值、修改),读取和删除、判断注册表项是否存在、判断键值是否存在。

要操作注册表需要引用命名空间Microsoft.Win32

以下从‘读’‘写’‘删除’‘判断’四个事例实现对注册表的简单操作

1.读取指定名称的注册表的值

  1. private string GetRegistData(string name) 
  2.    string registData; 
  3.    RegistryKey hkml = Registry.LocalMachine; 
  4.    RegistryKey software = hkml.OpenSubKey("SOFTWARE",true); 
  5.    RegistryKey aimdir = software.OpenSubKey("XXX",true); 
  6.    registData = aimdir.GetValue(name).ToString(); 
  7.    return registData; 
  8. }

以上是读取的注册表中HKEY_LOCAL_MACHINE/SOFTWARE目录下的XXX目录中名称为name的注册表值;

2.向注册表中写数据

  1. private void WTRegedit(string name,string tovalue) 
  2.    RegistryKey hklm = Registry.LocalMachine; 
  3.    RegistryKey software = hklm.OpenSubKey("SOFTWARE",true); 
  4.    RegistryKey aimdir = software.CreateSubKey("XXX"); 
  5.    aimdir.SetValue(name,tovalue); 

以上是在注册表中HKEY_LOCAL_MACHINE/SOFTWARE目录下新建XXX目录并在此目录下创建名称为name值为tovalue的注册表项;

3.删除注册表中指定的注册表项

  1. private void DeleteRegist(string name) 
  2.    string[] aimnames; 
  3.    RegistryKey hkml = Registry.LocalMachine; 
  4.    RegistryKey software = hkml.OpenSubKey("SOFTWARE",true); 
  5.    RegistryKey aimdir = software.OpenSubKey("XXX",true); 
  6.    aimnames = aimdir.GetSubKeyNames(); 
  7.    foreach(string aimKey in aimnames) 
  8.    { 
  9.      if(aimKey == name) 
  10.      aimdir.DeleteSubKeyTree(name); 
  11.    } 

以上是在注册表中HKEY_LOCAL_MACHINE/SOFTWARE目录下XXX目录中删除名称为name注册表项;

4.判断指定注册表项是否存在

  1. private bool IsRegeditExit(string name) 
  2.    bool _exit = false
  3.    string[] subkeyNames; 
  4.    RegistryKey hkml = Registry.LocalMachine; 
  5.    RegistryKey software = hkml.OpenSubKey("SOFTWARE",true); 
  6.    RegistryKey aimdir = software.OpenSubKey("XXX",true); 
  7.    subkeyNames = aimdir.GetSubKeyNames(); 
  8.    foreach(string keyName in subkeyNames) 
  9.    { 
  10.      if(keyName == name) 
  11.      { 
  12.        _exit = true
  13.        return _exit; 
  14.      } 
  15.    } 
  16.    return _exit; 

以上是在注册表中HKEY_LOCAL_MACHINE/SOFTWARE目录下XXX目录中判断名称为name注册表项是否存在,这一方法在删除注册表时已经存在,在新建一注册表项时也应有相应判断;

  C#就可以十分方便、简洁的开发出操作注册表的程序。单击"开始/运行",在"打开"的后面填入"regedit"。就可以看到注册表的数据结构了。"主键"是有层次结构的。主键的下一级主键称为该主键的"子键"。每一个主键可以对拥有多个子键。右边的这些值就是所谓的键值了。每一个主键或者子键都可以拥有多个键值。注册表是一个庞大的数据库,在其中每一个主键,每一个键值都赋予了不同的功能。
  C#如何读取注册表中的主键和键值:在.Net FrameWork SDK Beta 2版中,有一个Microsoft.Win32的名称空间,在此名称空间中提供了二个用于注册表操作的类:Registry类、RegistryKey类。这二个类都是封闭类,不可以继承。这二个类定义了许多关于注册表的方法和属性,通过调用这二个类,在Visual C#中就可以比较轻松的处理关于注册表的各种操作了。
  (1).Registry类:此类主要封装了七个公有的静态域,而这些静态域分别代表这视窗注册表中的七个基本的主键,具体如下所示:
Registry.ClassesRoot     对应于HKEY_CLASSES_ROOT主键
Registry.CurrentUser     对应于HKEY_CURRENT_USER主键
Registry.LocalMachine     对应于 HKEY_LOCAL_MACHINE主键
Registry.User             对应于 HKEY_USER主键
Registry.CurrentConfig   对应于HEKY_CURRENT_CONFIG主键
Registry.DynDa           对应于HKEY_DYN_DATA主键
Registry.PerformanceData 对应于HKEY_PERFORMANCE_DATA主键
  (2).RegistryKey类:此类中主要封装了对视窗系统注册表的基本操作。在程序设计中,首先通过Registry类找到注册表中的基本主键,然后通过RegistryKey类,来找其下面的子键和处理具体的操作的。
     下面通过一个读取注册表信息例子来具体说明这二个来的用法。
程序设计和运行的环境:Windows 2000服务器版,.Net FrameWork SDK Beta 2版。
在运行程序前的一些必要的处理工作。在程序设计时,主要功能是读取已经存在的主键键值,用户可以新建若干个主键和对应的键值。
     程序的主要功能是读取指定主键下面的所有子键和子键拥有的键值,并以列表的形式按层次显示出来。程序设计过程中的重要步骤以及应该注意的一些问题:
     程序中读取主键、子键和键值所使用到的方法: 程序中为了读取指定主键下面的子键和子键中拥有的键值,主要使用了RegistryKey类中的四个方法:OpenSubKey,GetSubKeyNames,GetValueNames,GetValue。具体的用法和意思如下:
OpenSubKey ( string name )方法主要是打开指定的子键。
GetSubKeyNames ( )方法是获得主键下面的所有子键的名称,它的返回值是一个字符串数组。
GetValueNames ( )方法是获得当前子键中的所有的键名称,它的返回值也是一个字符串数组。
GetValue ( string name )方法是指定键的键值。
程序中具体的使用语句如下:

  1. RegistryKey hklm = Registry.LocalMachine ;
  2. //打开"SYSTEM"子键
  3. RegistryKey software = hklm.OpenSubKey ( "SYSTEM" ) ;
  4. //打开"001"子键
  5. RegistryKey no1 = software.OpenSubKey ( "001" ) ;
  6. //打开"002"子键
  7. RegistryKey no2 = no1.OpenSubKey ( "002" ) ;

其中listBox1是程序中定义了的列表名称。

  1. foreach ( string site in no2.GetSubKeyNames ( ) )
  2. //开始遍历由子键名称组成的字符串数组
  3. {
  4. listBox1.Items.Add ( site ) ;
  5. //在列表中加入子键名称
  6. RegistryKey sitekey = no2.OpenSubKey ( site ) ;
  7. //打开此子键
  8.     foreach ( string sValName in sitekey.GetValueNames ( ) )
  9.     //开始遍历由指定子键拥有的键值名称组成的字符串数组
  10.     {
  11.        listBox1.Items.Add ( ""   sValName   ": "   sitekey.GetValue ( sValName ) ) ;
  12.        //在列表中加入键名称和对应的键值
  13.     }
  14. }

通过以上的论述,我们可以得到程序的源程序代码,具体如下:

  1. using System ;
  2. using System.Drawing ;
  3. using System.Collections ;
  4. using System.ComponentModel ;
  5. using System.Windows.Forms ;
  6. using System.Data ;
  7. using Microsoft.Win32 ; 
  8. public class Form1 : Form
  9. {
  10.     private System.ComponentModel.Container components ;
  11.     private ListBox listBox1 ;
  12.     private Button button1 ;
  13.     public Form1 ( )
  14.     {
  15.        InitializeComponent ( ) ;
  16.     }
  17.     //清除在程序中使用过的资源
  18.     public override void Dispose ( )
  19.     {
  20.        base.Dispose ( ) ;
  21.        components.Dispose ( ) ;
  22.     }
  23.     //初始化程序中使用到的组件
  24.     private void InitializeComponent ( )
  25.     {
  26.        this.components = new System.ComponentModel.Container ( ) ;
  27.        this.button1 = new Button ( ) ;
  28.        this.listBox1 = new ListBox ( ) ;
  29.        button1.Location = new System.Drawing.Point ( 16 , 320 ) ;
  30.        button1.Size = new System.Drawing.Size ( 75 , 23 ) ;
  31.        button1.TabIndex = 0 ;
  32.        button1.Text = "读取注册表" ;
  33.        button1.Click   = new System.EventHandler( this.button1_Click ) ;
  34.        listBox1.Location = new System.Drawing.Point ( 16 , 32 ) ;
  35.        listBox1.Size = new System.Drawing.Size ( 496 , 264 ) ;
  36.        listBox1.TabIndex = 1 ;
  37.        this.Text = "读取主测表信息" ;
  38.        this.AutoScaleBaseSize = new System.Drawing.Size ( 5 , 13 ) ;
  39.        this.ClientSize = new System.Drawing.Size ( 528 , 357 ) ;
  40.        this.Controls.Add( this.listBox1 ) ;
  41.        this.Controls.Add ( this.button1 ) ;
  42.     }
  43.     //
  44.     protected void button1_Click ( object sender , System.EventArgs e )
  45.     {
  46.        listBox1.Items.Clear ( ) ;
  47.        RegistryKey hklm = Registry.LocalMachine ;
  48.        RegistryKey software = hklm.OpenSubKey ( "SYSTEM" ) ;
  49.        //打开"SYSTEM"子键
  50.        RegistryKey no1 = software.OpenSubKey ( "001" ) ;
  51.        //打开"001"子键
  52.        RegistryKey no2 = no1.OpenSubKey ( "002" ) ;
  53.        //打开"002"子键
  54.        foreach ( string site in no2.GetSubKeyNames ( ) )
  55.        //开始遍历由子键名称组成的字符串数组
  56.        {
  57.        listBox1.Items.Add ( site ) ;
  58.        //在列表中加入子键名称
  59.        RegistryKey sitekey = no2.OpenSubKey ( site ) ;
  60.        //打开此子键
  61.            foreach ( string sValName in sitekey.GetValueNames ( ) )
  62.            //开始遍历由指定子键拥有的键值名称组成的字符串数组
  63.            {
  64.              listBox1.Items.Add ( ""   sValName   ": "   sitekey.GetValue ( sValName ) ) ;
  65.              //在列表中加入键名称和对应的键值
  66.            }
  67.        }
  68.     }
  69.     //
  70.     public static void Main ( )
  71.     {
  72.        Application.Run ( new Form1 ( ) ) ;
  73.     }
  74. }

  用C#读取注册表中的注册信息是通过名称空间Micorsoft.Win32中的二个类来实现的。在这二个类中还定义了对注册表信息的删除、修改和重命名的一些方法。这些方法比起本文介绍的读取方法、打开方法来说,更具有破坏性,但也更实用。由于注册表在视窗系统中的重要作用,所以在每一次对注册表进行操作之前,一定要备份,在操作的时候也要非常小心,因为一次的误操作都可能导致系统崩溃。

 

例:C#如何修改计算机的完整的计算机名称

下面是我写的代码,其中窗体里有两个label和两个textBox还有两个button.代码如下:

  1. using System;
  2. using System.Collections.Generic;
  3. using System.ComponentModel;
  4. using System.Data;
  5. using System.Drawing;
  6. using System.Text;
  7. using System.Windows.Forms;
  8. using System.Media;
  9. using Microsoft.Win32;
  10. namespace WindowsApplication1
  11. {
  12.     public partial class Form1 : Form
  13.     {
  14.         public Form1()
  15.         {
  16.             InitializeComponent();
  17.         }
  18.         private void Form1_Load(object sender, EventArgs e)
  19.         {
  20.             RegistryKey myRKCN = Registry.LocalMachine.OpenSubKey("SYSTEM//ControlSet001//Services//Tcpip//Parameters");
  21.             foreach (string myCpName in myRKCN.GetValueNames())
  22.             {
  23.                 if (myCpName == "NV Hostname")
  24.                 {
  25.                     this.textBox1.Text = myRKCN.GetValue(myCpName).ToString();
  26.                 }
  27.                 else
  28.                 {
  29.                     continue;
  30.                 }
  31.             }
  32.         }
  33.         private void button2_Click(object sender, EventArgs e)
  34.         {
  35.             RegistryKey myRKCN = Registry.LocalMachine.OpenSubKey("SYSTEM//ControlSet001//Services//Tcpip//Parameters",true);
  36.             foreach (string site in myRKCN.GetValueNames())
  37.             {
  38.                 if (site == "NV Hostname")
  39.                 {
  40.                     myRKCN.DeleteValue(site, false);
  41.                     myRKCN.SetValue("NV Hostname"this.textBox2.Text);
  42.                 }
  43.                 else
  44.                 {
  45.                     continue;
  46.                 }
  47.             }
  48.             MessageBox.Show("修改成功");
  49.         }
  50.         private void button1_Click(object sender, EventArgs e)
  51.         {
  52.             this.Close();
  53.         }
  54.     }
  55. }

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值