简单的读写注册表实例
2014-08-08 20:35
337 查看
一、说明:
注册表是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. 还有一个,一般不会出现,只有配置的局域网后才会有。
(二)、CRegKey 类及主要使用和函数说明
1. 所需要头文件:atlbase.h
2. 常用函数
☆ 打开一个键的函数:RegOpenKeyEx
函数定义:LONG RegOpenKeyEx(HKEY hKey,//已经打开的键的句柄,或者直接是上述几个根键
LPCTSTR lpSubKey,//要打开的子键名字的地址
DWord ulOptions,//保留值,必须为0
REGSAM samDesired,//打开方式,如读还是写
PHKEY phkResult//返回的打开的子键的句柄
);
☆ 查询某一个键值:RegQueryValueEx
函数定义:LONG RegQueryValueEx(HKEY hKey,//要查询的键的句柄
LPCTSTR lpValueName,//要查询的键值的名称
LPDWORD lPReserved,//保留值
LPDWORD lpType,//要查询的数据的类型
LPBYTE lpData,//要返回的查询的数据
LPDWORD lpcbData//预置的数据的长度
);
☆ 设置一个键值RegSetValueEx
函数定义:LONG RegSetValueEx(HKEY hKey,//要设置的键的句柄
LPCTSTR lpValueName,//要访问的键值的名称
LPDWORD lpReserved,//保留值
DWORD dwType,//要设置的数据的类型
const BYTE *lpData,//要设置的健值
DWORD cbData//数据的长度
);
二、实例:
1. 通过AppWizard创建基于对话框的程序
Regedit
2.
设置两个命令按钮,名为“查询”(ID_QUERY)和“修改”(ID_CHANGE),用来查询和修改注册表中用户姓名和公司名称。注:信息位置9x系列:\HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrntVersion
NT系列:\HKEY_LOCAL_MACHINE\Software\Microsoft\Windows
NT\CurrntVersion
键值:RegisteredOwnertkg和RegisteredOrganization分别表示用户名和公司名
3.
设置两个编辑框,用于显示和修改信息。定义两个CString变量m_strOwner,m_Company。
4. “查询”按钮代码如下:
void CRegeditDlg::OnQuery()
{
UpdateData(true);
HKEY hKEY;//定义有关的hKEY,在查询结束时要关闭
//打开与路径 data_Set相关的hKEY
LPCTSTR data_Set="Software\\Microsoft\\Windows
NT\\CurrentVersion\\";
//访问注册表,hKEY则保存此函数所打开的键的句柄
long
ret0=(::RegOpenKeyEx(HKEY_LOCAL_MACHINE,data_Set,0,KEY_READ,&hKEY));
if(ret0!=ERROR_SUCCESS)//如果无法打开hKEY,则中止程序的执行
{
AfxMessageBox("错误:无法打开有关的hKEY");
return;
}
//查询有关的数据
LPBYTE owner_Get=new BYTE[80];//定义用户姓名 owner_Get
DWORD type_1=REG_SZ;//定义数据类型
DWORD cbData_1=80;//定义数据长度
long
ret1=::RegQueryValueEx(hKEY,"RegisteredOwner",NULL,&type_1,owner_Get,&cbData_1);
i
c2b5
f(ret1!=ERROR_SUCCESS)
{
AfxMessageBox("错误:无法查询有关的注册表信息");
return;
}
//查询公司名
LPBYTE company_Get=new BYTE[80];//定义公司名称 company_Get
DWORD type_2=REG_SZ;//定义数据类型
DWORD cbData_2=80;//定义数据长度
long
ret2=::RegQueryValueEx(hKEY,"RegisteredOrganization",NULL,&type_2,company_Get,&cbData_2);
if(ret2!=ERROR_SUCCESS)
{
AfxMessageBox("错误:无法查询有关的注册表信息");
return;
}
//显示信息
m_strOwner=CString(owner_Get);
m_strCompany=CString(company_Get);
delete[] owner_Get;
delete[] company_Get;
//程序结束,关闭打开的hKEY
::RegCloseKey(hKEY);
UpdateData(false);
}
5. “设置”按钮代码如下:
void CRegeditDlg::OnModify()
{
UpdateData(true);
HKEY hKEY;//定义有关的hKEY,在查询结束时要关闭
//打开与路径 data_Set相关的hKEY
LPCTSTR data_Set="Software\\Microsoft\\Windows
NT\\CurrentVersion\\";
//访问注册表,hKEY则保存此函数所打开的键的句柄
long
ret0=(::RegOpenKeyEx(HKEY_LOCAL_MACHINE,data_Set,0,KEY_READ,&hKEY));
if(ret0!=ERROR_SUCCESS)//如果无法打开hKEY,则中止程序的执行
{
AfxMessageBox("错误:无法打开有关的hKEY");
return;
}
//设置有关的数据
//CString_To_LPBYTE,请参考下面的函数
LPBYTE owner_Set=CString_To_LPBYTE(m_strOwner);//定义用户姓名
owner_Set
DWORD type_1=REG_SZ;//定义数据类型
DWORD cbData_1=m_strOwner.GetLength()+1;//定义数据长度
long
ret1=::RegSetValueEx(hKEY,"RegisteredOwner",NULL,type_1,owner_Set,cbData_1);
if(ret1!=ERROR_SUCCESS)
{
AfxMessageBox("错误:无法设置有关的注册表信息");
return;
}
//查询公司名
LPBYTE company_Set=CString_To_LPBYTE(m_strCompany);//定义公司名称
company_Set
DWORD type_2=REG_SZ;//定义数据类型
DWORD cbData_2=m_strCompany.GetLength()+1;//定义数据长度
long
ret2=::RegSetValueEx(hKEY,"RegisteredOrganization",NULL,type_2,company_Set,cbData_2);
if(ret2!=ERROR_SUCCESS)
{
AfxMessageBox("错误:无法设置有关的注册表信息");
return;
}
else
{
AfxMessageBox("注册表修改完成");
}
//程序结束,关闭打开的hKEY
::RegCloseKey(hKEY);
UpdateData(false);
}
6. 参考函数
LPBYTE CString_To_LPBYTE(CString str)
{
LPBYTE lpb=new BYTE[str.GetLength()+1];
for(int i=0;i
lpb[i]=str[i];
lpb[str.GetLength()]=0;
return lpb;
}
注册表是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. 还有一个,一般不会出现,只有配置的局域网后才会有。
(二)、CRegKey 类及主要使用和函数说明
1. 所需要头文件:atlbase.h
2. 常用函数
☆ 打开一个键的函数:RegOpenKeyEx
函数定义:LONG RegOpenKeyEx(HKEY hKey,//已经打开的键的句柄,或者直接是上述几个根键
LPCTSTR lpSubKey,//要打开的子键名字的地址
DWord ulOptions,//保留值,必须为0
REGSAM samDesired,//打开方式,如读还是写
PHKEY phkResult//返回的打开的子键的句柄
);
☆ 查询某一个键值:RegQueryValueEx
函数定义:LONG RegQueryValueEx(HKEY hKey,//要查询的键的句柄
LPCTSTR lpValueName,//要查询的键值的名称
LPDWORD lPReserved,//保留值
LPDWORD lpType,//要查询的数据的类型
LPBYTE lpData,//要返回的查询的数据
LPDWORD lpcbData//预置的数据的长度
);
☆ 设置一个键值RegSetValueEx
函数定义:LONG RegSetValueEx(HKEY hKey,//要设置的键的句柄
LPCTSTR lpValueName,//要访问的键值的名称
LPDWORD lpReserved,//保留值
DWORD dwType,//要设置的数据的类型
const BYTE *lpData,//要设置的健值
DWORD cbData//数据的长度
);
二、实例:
1. 通过AppWizard创建基于对话框的程序
Regedit
2.
设置两个命令按钮,名为“查询”(ID_QUERY)和“修改”(ID_CHANGE),用来查询和修改注册表中用户姓名和公司名称。注:信息位置9x系列:\HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrntVersion
NT系列:\HKEY_LOCAL_MACHINE\Software\Microsoft\Windows
NT\CurrntVersion
键值:RegisteredOwnertkg和RegisteredOrganization分别表示用户名和公司名
3.
设置两个编辑框,用于显示和修改信息。定义两个CString变量m_strOwner,m_Company。
4. “查询”按钮代码如下:
void CRegeditDlg::OnQuery()
{
UpdateData(true);
HKEY hKEY;//定义有关的hKEY,在查询结束时要关闭
//打开与路径 data_Set相关的hKEY
LPCTSTR data_Set="Software\\Microsoft\\Windows
NT\\CurrentVersion\\";
//访问注册表,hKEY则保存此函数所打开的键的句柄
long
ret0=(::RegOpenKeyEx(HKEY_LOCAL_MACHINE,data_Set,0,KEY_READ,&hKEY));
if(ret0!=ERROR_SUCCESS)//如果无法打开hKEY,则中止程序的执行
{
AfxMessageBox("错误:无法打开有关的hKEY");
return;
}
//查询有关的数据
LPBYTE owner_Get=new BYTE[80];//定义用户姓名 owner_Get
DWORD type_1=REG_SZ;//定义数据类型
DWORD cbData_1=80;//定义数据长度
long
ret1=::RegQueryValueEx(hKEY,"RegisteredOwner",NULL,&type_1,owner_Get,&cbData_1);
i
c2b5
f(ret1!=ERROR_SUCCESS)
{
AfxMessageBox("错误:无法查询有关的注册表信息");
return;
}
//查询公司名
LPBYTE company_Get=new BYTE[80];//定义公司名称 company_Get
DWORD type_2=REG_SZ;//定义数据类型
DWORD cbData_2=80;//定义数据长度
long
ret2=::RegQueryValueEx(hKEY,"RegisteredOrganization",NULL,&type_2,company_Get,&cbData_2);
if(ret2!=ERROR_SUCCESS)
{
AfxMessageBox("错误:无法查询有关的注册表信息");
return;
}
//显示信息
m_strOwner=CString(owner_Get);
m_strCompany=CString(company_Get);
delete[] owner_Get;
delete[] company_Get;
//程序结束,关闭打开的hKEY
::RegCloseKey(hKEY);
UpdateData(false);
}
5. “设置”按钮代码如下:
void CRegeditDlg::OnModify()
{
UpdateData(true);
HKEY hKEY;//定义有关的hKEY,在查询结束时要关闭
//打开与路径 data_Set相关的hKEY
LPCTSTR data_Set="Software\\Microsoft\\Windows
NT\\CurrentVersion\\";
//访问注册表,hKEY则保存此函数所打开的键的句柄
long
ret0=(::RegOpenKeyEx(HKEY_LOCAL_MACHINE,data_Set,0,KEY_READ,&hKEY));
if(ret0!=ERROR_SUCCESS)//如果无法打开hKEY,则中止程序的执行
{
AfxMessageBox("错误:无法打开有关的hKEY");
return;
}
//设置有关的数据
//CString_To_LPBYTE,请参考下面的函数
LPBYTE owner_Set=CString_To_LPBYTE(m_strOwner);//定义用户姓名
owner_Set
DWORD type_1=REG_SZ;//定义数据类型
DWORD cbData_1=m_strOwner.GetLength()+1;//定义数据长度
long
ret1=::RegSetValueEx(hKEY,"RegisteredOwner",NULL,type_1,owner_Set,cbData_1);
if(ret1!=ERROR_SUCCESS)
{
AfxMessageBox("错误:无法设置有关的注册表信息");
return;
}
//查询公司名
LPBYTE company_Set=CString_To_LPBYTE(m_strCompany);//定义公司名称
company_Set
DWORD type_2=REG_SZ;//定义数据类型
DWORD cbData_2=m_strCompany.GetLength()+1;//定义数据长度
long
ret2=::RegSetValueEx(hKEY,"RegisteredOrganization",NULL,type_2,company_Set,cbData_2);
if(ret2!=ERROR_SUCCESS)
{
AfxMessageBox("错误:无法设置有关的注册表信息");
return;
}
else
{
AfxMessageBox("注册表修改完成");
}
//程序结束,关闭打开的hKEY
::RegCloseKey(hKEY);
UpdateData(false);
}
6. 参考函数
LPBYTE CString_To_LPBYTE(CString str)
{
LPBYTE lpb=new BYTE[str.GetLength()+1];
for(int i=0;i
lpb[i]=str[i];
lpb[str.GetLength()]=0;
return lpb;
}
相关文章推荐
- 一个简单的读写注册表实例
- 一个简单的读写注册表实例
- 一个简单的读写注册表实例
- 一个简单的读写注册表实例
- 一个简单的读写注册表实例
- 一个简单的读写注册表实例
- Python 读写文件的两个简单实例
- 一个简单的文件读写实例
- C++文件简单的读写操作实例
- IPC 简单的读写通信实例 linux环境高级编程
- LINUX 简单的串口读写实例
- Apache POI:Java程序读写Microsoft Office格式文档——简单完整实例讲解
- LINUX 简单的串口读写实例
- vc++注册表简单操作实例
- c++简单的文本文件读写实例
- C#读写注册表(简单实用易懂)
- Java中读写锁的实现及使用读写锁简单实现缓存系统的实例
- 简单实例-ASCII文件的读写操作(读入字符,将其中的小写字母改为大写字母)
- 用VB5读写注册表实例
- java中读写锁的实现及使用读写锁简单实现缓存系统的实例