打开注册表键
LONG RegOpenKeyEx( HKEY hKey, // handle to open key主键 LPCTSTR lpSubKey, // subkey name子键 DWORD ulOptions, // reserved。必须是0 REGSAM samDesired, // security access mask读写标识 PHKEY phkResult // handle to open key返回的HKEY类型的指针。以后,读写,关闭用这个指针 );
如:
// 打开HKEY_LOCAL_MACHINE主键下的SoftWare\\Knight Studio\\Knight子键 HKEY hKEY; HKEY hKeyRoot = HKEY_LOCAL_MACHINE; long ret0=(::RegOpenKeyEx(hKeyRoot,"SoftWare\\Knight Studio\\Knight",0,KEY_READ,&hKEY)); if(ret0!=ERROR_SUCCESS)//如果无法打开hKEY,则中止程序的执行 { AfxMessageBox("错误:无法打开有关的hKEY"); return; }
读取注册表
LONG RegQueryValueEx( HKEY hKey, // handle to key打开注册表指针 LPCTSTR lpValueName, // value name要读取的键名称 LPDWORD lpReserved, // reserved must be NULL. 必须是NULL LPDWORD lpType, // type buffer,键类型。我最常用REG_SZ,REG_DWORD LPBYTE lpData, // data buffer。保存查询结果的缓冲区 LPDWORD lpcbData // size of data buffer。缓冲区大小 );
如:
// hKEY是上面打开时得到的指针。 LPBYTE getValue = new BYTE[80];//得到的键值 DWORD keyType = REG_SZ;//定义数据类型 DWORD DataLen = 80;//定义数据长度 CString strUser = _T("UserName");//要查询的键名称 long ret1=::RegQueryValueEx(hKEY,strUser,NULL,&keyType,getValue,&DataLen); if(ret1!=ERROR_SUCCESS) { AfxMessageBox("错误:无法查询有关的注册表信息"); return; }
写注册表
LONG RegSetValueEx( HKEY hKey, // handle to key。打开注册表的指针 LPCTSTR lpValueName, // value name 要写入的键 DWORD Reserved, // reserved 必须是0 DWORD dwType, // value type 写入值类型 CONST BYTE *lpData, // value data 要写入的数据 DWORD cbData // size of value data 。数据SIZE );
如:
// 写注册表。修改UserName为Knight // 写入CString类型的数据 CString strUser = _T("UserName");//要写入的键名称 LPCTSTR strUserValue = "Knight"; long ret = ::RegSetValueEx(hKEY, strUser, 0, REG_SZ, (const BYTE *) strUserValue, strlen(strUserValue)+1); if(ret1!=ERROR_SUCCESS) { AfxMessageBox("错误:无法查询有关的注册表信息"); return; }
创建一个新键
LONG RegCreateKeyEx( HKEY hKey, // handle to open key。打开的注册表指针 LPCTSTR lpSubKey, // subkey name。子键名称 DWORD Reserved, // reserved。必须为0 LPTSTR lpClass, // class string。已经存在时用,一般为NULL DWORD dwOptions, // special options //默认值REG_OPTION_VOLATILE,保存在注册表,下次开机仍然存在 //REG_OPTION_VOLATILE,保存在内存 //REG_OPTION_BACKUP_RESTORE REGSAM samDesired, // desired security access。操作权限。一般KEY_ALL_ACCESS,除非有特殊需要,请查阅MSDN LPSECURITY_ATTRIBUTES lpSecurityAttributes, // inheritance。继承性。一般为NULL PHKEY phkResult, // key handle 。返回该键值镇。 LPDWORD lpdwDisposition // disposition value buffer //REG_CREATED_NEW_KEY The key did not exist and was created. //REG_OPENED_EXISTING_KEY The key existed and was simply opened without being changed. );
删除一个键:
LONG RegDeleteKey( HKEY hKey, // handle to open key LPCTSTR lpSubKey // subkey name );
刷新注册表:
LONG RegFlushKey( HKEY hKey // handle to key to write。写入所有的值,在给定的指针 );
导入一个注册表文件到指定的键下:
LONG RegLoadKey( HKEY hKey, // handle to open key LPCTSTR lpSubKey, // subkey name LPCTSTR lpFile // registry file name );
关闭打开的注册表:
LONG RegCloseKey( HKEY hKey // handle to key to close );
实例
(1)读取注册表
1).查看HKEY_CURRENT_USER主键下Software//武汉帷幄信息技术有限公司//施工工艺决策系统//系统配置//BCGPGanttControls//GanttChartBCGPGantt-0子键中名称为GridProgressColumnIndex的值,其类型为DWORD。
void OnBnClickedQuery() //响应按钮IDC_QUERY
{
//定义有关的hKEY,在查询结束时要关闭
HKEY hKEY;
//打开与路径data_Set相关的hKEY
LPCTSTR data_Set= _T("/Software//武汉帷幄信息技术有限公司//施工工艺决策系统//系统配置//BCGPGanttControls//GanttChartBCGPGantt-0");
//访问注册表,hKEY则保存此函数所打开的键的句柄
if (ERROR_SUCCESS == ::RegOpenKeyEx(HKEY_CURRENT_USER,data_Set,0,KEY_READ,&hKEY))
{
DWORD dwValue;
DWORD dwSize = sizeof(DWORD);
DWORD dwType = REG_DWORD;
if (::RegQueryValueEx(hKEY,_T("GridProgressColumnIndex"), 0, &dwType, (LPBYTE)&dwValue, &dwSize) != ERROR_SUCCESS)
{
AfxMessageBox(_T("错误:无法查询有关的注册表信息"));
}
//程序结束,关闭打开的hKEY
::RegCloseKey(hKEY);
}
UpdateData(false);
// TODO: 在此添加控件通知处理程序代码
}
可以看到读取的注册表GridProgressColumnIndex的值是正确的。
2).查看HKEY_LOCAL_MACHINE主键下SOFTWARE//Microsoft//Windows NT//CurrentVersion子键中名称为"SoftwareType的值,其类型为REG_SZ。
void OnBnClickedQuery()
{
HKEY hKEY;//定义有关的hKEY,在查询结束时要关闭
//打开与路径data_Set相关的hKEY
LPCTSTR data_Set= _T("SOFTWARE//Microsoft//Windows NT//CurrentVersion");
//访问注册表,hKEY则保存此函数所打开的键的句柄
if (ERROR_SUCCESS == ::RegOpenKeyEx(HKEY_LOCAL_MACHINE,data_Set,0,KEY_READ,&hKEY))
{
char dwValue[256];
DWORD dwSzType = REG_SZ;
DWORD dwSize = sizeof(dwValue);
if (::RegQueryValueEx(hKEY,_T("SoftwareType"), 0, &dwSzType, (LPBYTE)&dwValue, &dwSize) != ERROR_SUCCESS)
{
AfxMessageBox(_T("错误:无法查询有关的注册表信息"));
}
//程序结束,关闭打开的hKEY
::RegCloseKey(hKEY);
}
UpdateData(false);
// TODO: 在此添加控件通知处理程序代码
}
(2)写注册表
1).在HKEY_CURRENT_USER主键下写一个Software//武汉帷幄信息技术有限公司//test111子键,设置其名称为Name,类型为DWORD,值为6。
void OnBnClickedChange()//响应按钮IDC_CHANGE
{
HKEY hKey;//定义有关的hKEY,在查询结束时要关闭
HKEY hTempKey;
DWORD dwValue = 6;
DWORD dwSize = sizeof(DWORD);
DWORD dwType = REG_DWORD;
//打开与路径data_Set相关的hKEY
LPCTSTR data_Set= _T("Software//武汉帷幄信息技术有限公司");
if (ERROR_SUCCESS == ::RegOpenKeyEx(HKEY_CURRENT_USER, data_Set,0,KEY_SET_VALUE, &hKey))
{
// 使用hKey来操作data_Set这个KEY里面的值。
if (ERROR_SUCCESS == ::RegCreateKey(hKey, _T("test111"), &hTempKey))
{//背景色
if (ERROR_SUCCESS != ::RegSetValueEx(hTempKey, _T("Name"), 0,REG_DWORD, (CONST BYTE*)&dwValue, sizeof(DWORD)))
{
AfxMessageBox(_T("错误"));
::RegCloseKey(hKey);
return;
}
}
}
::RegCloseKey(hKey);
// TODO: 在此添加控件通知处理程序代码
}
2).在HKEY_CURRENT_USER主键下写一个Software//武汉帷幄信息技术有限公司//test111子键,设置其名称为Name,类型为REG_SZ,值为China。
void OnBnClickedChange()
{
HKEY hKey;//定义有关的hKEY,在查询结束时要关闭
HKEY hTempKey;
CString m_name = "China";
LPBYTE m_name_Set = CString_To_LPBYTE(m_name);//定义x轴名称
DWORD length = m_name.GetLength() + 1;//定义数据长度
//打开与路径data_Set相关的hKEY
LPCTSTR data_Set= _T("Software//武汉帷幄信息技术有限公司");
if (ERROR_SUCCESS == ::RegOpenKeyEx(HKEY_CURRENT_USER, data_Set,0,KEY_SET_VALUE, &hKey))
{
// 使用hKey来操作data_Set这个KEY里面的值。
if (ERROR_SUCCESS == ::RegCreateKey(hKey, _T("test111"), &hTempKey))
{
if (ERROR_SUCCESS != ::RegSetValueEx(hTempKey, _T("Name"), 0,REG_SZ, m_name_Set, length))
{
AfxMessageBox(_T("错误"));
::RegCloseKey(hKey);
return;
}
}
}
::RegCloseKey(hKey);
UpdateData(false);
// TODO: 在此添加控件通知处理程序代码
}
3).在HKEY_CURRENT_USER主键下写一个Software//武汉帷幄信息技术有限公司//test111子键,设置其名称为Name,类型为REG_ BINARY,值为ff ac 05 4e。
void OnBnClickedChange()
{
HKEY hKey;//定义有关的hKEY,在查询结束时要关闭
HKEY hTempKey;
BYTE m_name[10];
memset(m_name, 0, sizeof(m_name));//将数组m_name清零
m_name[0] = 0xff;
m_name[1] = 0xac;
m_name[2] = 0x05;
m_name[4] = 0x4e;
//打开与路径data_Set相关的hKEY
LPCTSTR data_Set= _T("Software//武汉帷幄信息技术有限公司");
if (ERROR_SUCCESS == ::RegOpenKeyEx(HKEY_CURRENT_USER, data_Set,0,KEY_SET_VALUE, &hKey))
{
// 使用hKey来操作data_Set这个KEY里面的值。
if (ERROR_SUCCESS == ::RegCreateKey(hKey, _T("test111"), &hTempKey))
{
if (ERROR_SUCCESS != ::RegSetValueEx(hTempKey, _T("Name"), 0,REG_BINARY,(unsigned char *)m_name,5))
{
AfxMessageBox(_T("错误"));
::RegCloseKey(hKey);
return;
}
}
}
::RegCloseKey(hKey);
UpdateData(false);
// TODO: 在此添加控件通知处理程序代码
}
(3)删除注册表
1).删除HKEY_CURRENT_USER//Software//武汉帷幄信息技术有限公司//test111的键值Name
void OnBnClickedDelete()
{
HKEY hKey;//定义有关的hKEY,在查询结束时要关闭
//打开与路径data_Set相关的hKEY
LPCTSTR data_Set= _T("Software//武汉帷幄信息技术有限公司//test111");
if (ERROR_SUCCESS == ::RegOpenKeyEx(HKEY_CURRENT_USER, data_Set,0,KEY_SET_VALUE, &hKey))
{
// 使用hKey来操作data_Set这个KEY里面的值。
if (ERROR_SUCCESS != ::RegDeleteValue(hKey, _T("Name")))
{
AfxMessageBox(_T("错误"));
::RegCloseKey(hKey);
return;
}
}
::RegCloseKey(hKey);
UpdateData(FALSE);
// TODO: 在此添加控件通知处理程序代码
}
2).删除HKEY_CURRENT_USER//Software//武汉帷幄信息技术有限公司下的子键
test111。
void OnBnClickedDelete()
{
HKEY hKey;//定义有关的hKEY,在查询结束时要关闭
//打开与路径data_Set相关的hKEY
LPCTSTR data_Set= _T("Software//武汉帷幄信息技术有限公司");
if (ERROR_SUCCESS == ::RegOpenKeyEx(HKEY_CURRENT_USER, data_Set,0,KEY_SET_VALUE, &hKey))
{
// 使用hKey来操作data_Set这个KEY里面的值。
if (ERROR_SUCCESS != ::RegDeleteKey(hKey, "test111"))
{
AfxMessageBox(_T("错误"));
::RegCloseKey(hKey);
return;
}
}
::RegCloseKey(hKey);
UpdateData(FALSE);
// TODO: 在此添加控件通知处理程序代码
}