C++ 操作注册表-一亩菜园-搜狐博客

来源:百度文库 编辑:神马文学网 时间:2024/04/29 16:31:53
2007-04-19 | C++ 操作注册表
标签:s
本文只是对注册表实现简单的打开、创建、读、写、关闭操作,故只是基本知识的介绍,适合不能熟练使用注册表操作的初级读者。
一、说明:
注册表是Windows重要组成部分,注册表记录了大量有关电脑软硬件的信息。注册表中的值通过其名称标识。值名称由与键名相同的字符组成。值本身可以是字符串、二进制数据或者是32位无符号值。在这里我们主要运用以下技巧:
(一)、预定义的注册表键。注册表包含了几个预定义键:
1. HKEY_LOCAL_MACHINE  包含描述计算机及其配置的条目。其中包括关于处理器、系统主板、内存和已安装的软件和硬件的信息。
2. HKEY_CLASSES_ROOT   是与文档类型和 OLE\COM 相关的信息的支持键。这个键是 HKEY_LOCAL_MACHINE的从属键。
3. HKEY_USERS          用作默认用户首选设置,也作为单个用户的首选设置。
4. HKEY_CLASSES_USER   是用于当前(登录)用户的相关信息。
5. HKEY_CURRENT_CONFIG 包含了当前系统配置的信息。
6. 还有一个,一般不会出现,只有配置的局域网后才会有。
(二)、VC中两种注册表操作方法
在VC中,主要有两种方法可以实现注册表的操作,一是使用MFC封装的类CRegKey,该类包含了14个成员函数,它们可以实现注册表的简单操作(基本的如本文提到的“打开、创建、读、写、关闭”等);二是使用Windows API函数。当然,对我来说,能使用底层的,那为什么不用呢,毕竟我现在是程序员,使用底层函数,可以移植到更多的开发平台中嘛。
1.
所需要头文件:atlbase.h
该种方法可以使用类CRegKey中的成员函数来完成。先包含头文件,再申明一个类对象CRegKey RKey;然后就可以调用成员函数来操作了。
基本功能的成员函数:
LONG Open(HKEY hKeyParent, LPCTSTR lpszKeyName,REGSAM samDesired = KEY_ALL_ACCESS);
LONG Close();
LONG Create(HKEY hKeyParent, LPCTSTR lpszKeyName,
LPTSTR lpszClass = REG_NONE, DWORD dwOptions = REG_OPTION_NON_VOLATILE,
REGSAM samDesired = KEY_ALL_ACCESS,
LPSECURITY_ATTRIBUTES lpSecAttr = NULL,
LPDWORD lpdwDisposition = NULL);
LONG SetValue(DWORD dwValue, LPCTSTR lpszValueName);
LONG SetValue(LPCTSTR lpszValue, LPCTSTR lpszValueName = NULL);
LONG QueryValue(DWORD& dwValue, LPCTSTR lpszValueName);
LONG QueryValue(LPTSTR szValue, LPCTSTR lpszValueName, DWORD* pdwCount);
其他几个:
LONG SetKeyValue(LPCTSTR lpszKeyName, LPCTSTR lpszValue, LPCTSTR lpszValueName = NULL);
static LONG WINAPI SetValue(HKEY hKeyParent, LPCTSTR lpszKeyName,LPCTSTR lpszValue, LPCTSTR lpszValueName = NULL);
HKEY Detach();
void Attach(HKEY hKey);
LONG DeleteSubKey(LPCTSTR lpszSubKey);
LONG RecurseDeleteKey(LPCTSTR lpszKey);
LONG DeleteValue(LPCTSTR lpszValue);
但是本文主要介绍使用Windows API函数来操作注册表,所以这里不详细的介绍这些成员函数的用法了。
2.
Windows API函数个数比较多,一共有三、四十个,这里主要介绍几个常用的函数,来实现本文所说的基本功能即可。
常用API函数
☆ 打开一个键的函数:RegOpenKeyEx
函数定义:LONG RegOpenKeyEx(HKEY hKey,//已经打开的键的句柄,或者直接是上述几个根键
LPCTSTR lpSubKey,//要打开的子键名字的地址
DWORD ulOptions,//保留值,必须为0
REGSAM samDesired,//打开方式,如读还是写
PHKEY phkResult//返回的打开的子键的句柄
);
说明:如果指定的要打开的子键不存在,则返回失败;反之返回成功ERROR_SUCCESS;
☆ 创建一个键的函数:RegCreateKeyEx
函数定义:LONG RegCreateKeyEx(HKEY hKey,//已经打开的键的句柄,或者直接是上述几个根键
LPCTSTR lpSubKey,//要创建的子键名字的地址
DWORD ulOptions,//保留值,必须为0
REGSAM samDesired,//打开方式,如读还是写
PHKEY phkResult//返回的创建的子键的句柄
);
说明:如果指定的要创建的子键已经存在,则打开该子键;反之创建该子键。函数成功则返回ERROR_SUCCESS;
该子键可以一次创建多层子键,格式为“子键1层\\子键2层\\子键3层。。。”
☆ 查询某一个键值:RegQueryValueEx
函数定义:LONG RegQueryValueEx(HKEY hKey,//要查询的键的句柄
LPCTSTR lpValueName,//要查询的键值的名称
LPDWORD lpReserved,//保留值,必须为0
LPDWORD lpType,//要查询的数据的类型,如果不关心,可以为NULL
LPBYTE lpData,//要返回的查询的数据
LPDWORD lpcbData//预置的数据的长度,理论上可以为NULL,但实际我发现不行,最好设一个值
);
☆ 设置一个键值RegSetValueEx
函数定义:LONG RegSetValueEx(HKEY hKey,//要设置的键的句柄
LPCTSTR lpValueName,//要访问的键值的名称
LPDWORD lpReserved,//保留值
DWORD dwType,//要设置的数据的类型
const BYTE *lpData,//要设置的健值
DWORD cbData//数据的长度
);
说明:如果要写入的数据已经存在,只是改变值而已;如果不存在,则新建子键并存值。
张琳的代码:
HKEY hKEY;
LPCTSTR data_Set  =  "SOFTWARE\\WCIES";
//-------------- 打开注册表,如果打开失败,创建注册表,写值---------------
long ret0 =hKEY);  // 打开注册表父目录,取得句柄
if (ret0 != ERROR_SUCCESS)  //打开操作失败
{
long ret1 =:: RegCreateKey(HKEY_CURRENT_USER, data_Set, &hKEY);
if (ret1==ERROR_SUCCESS)
cout << "创建成功!" << endl;
int value = 64;  // value inserted
long ret2 =  ::RegSetValueEx(hKEY, "PicCount", 0, REG_DWORD, (BYTE *)&value, sizeof(int));  // 设置注册表值
if (ret2 == ERROR_SUCCESS)
cout <<"键值设置成功" <}
//-----------获取注册表值----------------------------
LPBYTE lpa  =  new BYTE[16];
DWORD theSize  =  16;
DWORD type  =  REG_SZ;
long ret3  =  ::RegQueryValueEx(hKEY, "PicCount", NULL, &type, lpa, &theSize);
unsigned int a;
memcpy(&a, lpa, sizeof(int));
cout << endl << "VALUE: " << a << endl;
//------------ 释放句柄-----------
long ret4 =
/*   //删除注册表值
HKEY hKEY;
LPCTSTR data_Set="SOFTWARE\\WCIES";
long ret0=::RegOpenKeyEx(HKEY_CURRENT_USER,data_Set, 0, KEY_ALL_ACCESS, &hKEY);
long ret1=::RegDeleteValue(hKEY,"123123");
long ret2=::RegCloseKey(hKEY);
*/