服务程序C#编写系统服务,注册表读写问题
2013-12-23 16:31
621 查看
默认情况下,服务与已登录的用户在不同的安全上下文中运行。服务在称为 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注册表项是否存
在,这一方法在删除注册表时已经存在,在新建一注册表项时也应有相应判断;
所以服务程序访问注册表的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注册表项是否存
在,这一方法在删除注册表时已经存在,在新建一注册表项时也应有相应判断;
相关文章推荐
- 服务程序C#编写系统服务,注册表读写问题
- C#编写WINNT服务,随便解决安卓开发遇到的5037被众多程序无节操占用的问题
- C#编写的windows程序随系统启动的问题
- C# 32位/64位系统下程序读写注册表之差异
- VC编写系统服务程序笔记
- Delphi编写系统服务四:如何限制系统服务和桌面程序只运行一个
- c# Windows 服务程序编写与调试
- 应对32位程序在64位系统上访问注册表和文件自动转向问题
- 关于C#程序调用AMFPHP服务的问题!!
- C#编写Windows服务程序图文教程
- C# 编写Windows Service(windows服务程序)
- C# 编写Windows Service(windows服务程序)
- C#编写Windows服务程序
- 编写有界面的系统服务程序
- Delphi编写系统服务二:系统服务和桌面程序的区别
- C#编写windows服务程序步骤
- C# Windows 服务 的简单程序的编写,安装 和 卸载
- C#编写Windows服务程序图文教程
- Delphi编写系统服务二:系统服务和桌面程序的区别
- 安装Vs2012后,编写Vc++程序找不到系统头文件和导致VS2010工程编译的问题