服务程序C#编写系统服务,注册表读写问题

来源:互联网 发布:php 获取当前地区 编辑:程序博客网 时间:2024/05/17 18:29

默认情况下,服务与已登录的用户在不同的安全上下文中运行。服务在称为 LocalSystem 的默认系统帐户的上下文中运行,该帐户给服务提供的系统资源访问特权不同于给用户提供的。
     所以服务程序访问注册表的CurrentUser时并不是你当前登陆账号下的CurrentUser,所以在你当前陆账号下的CurrentUser下建立的键值,服务程序根本无法访问到,给人的错觉就是服务程序无法读写注册表,其实不然,只是它读写的地方不是你想要它读写的地方。
    解决的办法有两个,一个是在服务管理器理,双击你的服务,在登录标签里修改服务的登录帐号为你当前的登录帐号,重启服务。
   第二个方法就是,采用注册表里的公共部分,如loacl machine,只要与登录帐号无关的键就可以。

 private void button3_Click(object sender, EventArgs e)
        {
                       RegistryKey regRead;
            //读取HKEY_CURRENT_USER主键里的Software子键下名为“Test”的子键
           // regRead = Registry.CurrentUser.OpenSubKey("SOFTWARE//JavaSoft//Prefs", true);
          //  regRead = Registry.CurrentUser.OpenSubKey("HKEY_LOCAL_MACHINE//HARDWARE//JavaSoft//Prefs", true);
            regRead = Registry.LocalMachine.OpenSubKey("HARDWARE//JavaSoft//Prefs", true);
            
            if (regRead == null) //如果该子键不存在
            {
                MessageBox.Show("No Data!");
            }
            else
            {
                object dbname = regRead.GetValue("dbname");  //读取“Name”项的值
                listBox1.Items.Add(dbname.ToString());
                object password = regRead.GetValue("password");  //读取“Name”项的值
                listBox1.Items.Add(password.ToString());
                object skyip = regRead.GetValue("skyip");  //读取“Name”项的值
                listBox1.Items.Add(skyip.ToString());
                object skyport = regRead.GetValue("skyport");  //读取“Name”项的值
                listBox1.Items.Add(skyport.ToString());
                object user = regRead.GetValue("user");  //读取“Name”项的值
                listBox1.Items.Add(user.ToString());
               
            }
            //关闭该对象
            regRead.Close();

 

        }

 

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主键

RegistryKey类封装了对注册表的基本操作,包括读取,写入,删除。其中读取的主要函数有:

OpenSubKey ( string name )方法主要是打开指定的子键。
  GetSubKeyNames ( )方法是获得主键下面的所有子键的名称,它的返回值是一个字符串数组。
  GetValueNames ( )方法是获得当前子键中的所有的键名称,它的返回值也是一个字符串数组。
  GetValue ( string name )方法是指定键的键值。

写入的函数有:

CreateSubKey(string name)方法是增加一个子键

SetValue(string name,string value)方法是设置一个键的键值



删除的函数:

DeleteSubKey ( )方法:删除一个指定的子键。

DeleteSubKeyTree ( )方法:

此方法是彻底删除指定的子键目录,即:删除该子键以及该子键以下的全部子键。
1.IE窗口的动感效果

//-------------------------------------

//  ChangeIE.cs ? 2004 by yudehui

//-------------------------------------

using System;

using Microsoft.Win32;  //对注册表操作一定要引用这个命名空间

namespace ChangeIE

{

    class ChangeIE

    {      

        [STAThread]

        static void Main(string[] args)

        {

          RegistryKey pregkey ;

            pregkey = Registry.CurrentUser.OpenSubKey("Control Panel//Desktop//WindowMetrics",true);

            if (pregkey==null) 

            {

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

            }

            else

            {

                pregkey.SetValue("MinAnimate","1");

                pregkey.SetValue("MaxAnimate","1");

                Console.WriteLine("修改成功");



            }

            pregkey. Close; 

        }

    }

}

2.改变IE工具栏的背景

//-------------------------------------

//  ChangeIE.cs ? 2004 by yudehui

//-------------------------------------

using System;

using Microsoft.Win32;  //对注册表操作一定要引用这个命名空间

namespace ChangeIEbackColor

{

    class ChangeIEbackColor

    {      

        [STAThread]

        static void Main(string[] args)

        {

          RegistryKey pregkey ;

pregkey = Registry.CurrentUser.OpenSubKey("Software//Microsoft//Internet" + 

                                          "Explorer//Toolbar//Explorer ",true);

            if (pregkey==null) 

            {

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

            }

            else

            {

                pregkey.SetValue("BackBitmap","C://windows//Greenstone.bmp");

                Console.WriteLine("修改成功");



            }

            pregkey.Close;

        }

    }

}
以下从‘读’‘写’‘删除’‘判断’四个事例实现对注册表的简单操作 
1.读取指定名称的注册表的值 
private string GetRegistData(string name) 

  string registData; 
  RegistryKey hkml = Registry.LocalMachine; 
  RegistryKey software = hkml.OpenSubKey("SOFTWARE",true); 
  RegistryKey aimdir = software.OpenSubKey("XXX",true); 
  registData = aimdir.GetValue(name).ToString(); 
  return registData; 

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

2.向注册表中写数据 
private void WTRegedit(string name,string tovalue) 

  RegistryKey hklm = Registry.LocalMachine; 
  RegistryKey software = hklm.OpenSubKey("SOFTWARE",true); 
  RegistryKey aimdir = software.CreateSubKey("XXX"); 
  aimdir.SetValue(name,tovalue); 

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

3.删除注册表中指定的注册表项 
private void DeleteRegist(string name) 

  string[] aimnames; 
  RegistryKey hkml = Registry.LocalMachine; 
  RegistryKey software = hkml.OpenSubKey("SOFTWARE",true); 
  RegistryKey aimdir = software.OpenSubKey("XXX",true); 
  aimnames = aimdir.GetSubKeyNames(); 
  foreach(string aimKey in aimnames) 
  { 
    if(aimKey == name) 
    aimdir.DeleteSubKeyTree(name); 
  } 

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

4.判断指定注册表项是否存在 
private bool IsRegeditExit(string name) 

  bool _exit = false; 
  string[] subkeyNames; 
  RegistryKey hkml = Registry.LocalMachine; 
  RegistryKey software = hkml.OpenSubKey("SOFTWARE",true); 
  RegistryKey aimdir = software.OpenSubKey("XXX",true); 
  subkeyNames = aimdir.GetSubKeyNames(); 
  foreach(string keyName in subkeyNames) 
  { 
    if(keyName == name) 
    { 
      _exit = true; 
      return _exit; 
    } 
  } 
  return _exit; 

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