C++ 注册表的读写

//

// 先写两个例子

 

const   char   _szLogSubKey[]   =   "SOFTWARE//SystemWalker/OutputAssist//Prform";  
  const   char   _szLogValueName[]   =   "LogFile";  
   
  void   Save(LPCTSTR   szLogFile)  
  {  
       HKEY hKey;  
       LONG rc;  
       int nLogFile;  
       rc   =   RegCreateKeyEx( HKEY_CURRENT_USER,   _szLogSubKey,   NULL,   NULL,   0,                                                KEY_WRITE,   NULL,   &hKey,   NULL);  
       if(rc   !=   ERROR_SUCCESS)  
           return;  
       nLogFile   =   strlen(szLogFile);  
       RegSetValueEx(hKey,   _szLogValueName,   NULL,   REG_SZ,   (LPBYTE)szLogFile,                                 nLogFile);  
       RegCloseKey(hKey);  
  }  
   
  BOOL   Get(int   nLogFile,   char   *szLogFile)  
  {  
       HKEY hKey;  
       LONG rc;  
       DWORD dwType;  
       DWORD dwLogFile   =   nLogFile;  
   
       rc   =   RegOpenKey(HKEY_CURRENT_USER,   _szLogSubKey,   &hKey);  
       if(rc   !=   ERROR_SUCCESS)  
             return   FALSE;  
       dwLogFile--;  
       rc   =   RegQueryValueEx(hKey,   _szLogValueName,   NULL,   &dwType,                                                 (LPBYTE) szLogFile,   &dwLogFile);  
       //   成功  
       if(   rc   ==   ERROR_SUCCESS   &&   dwType   ==   REG_SZ)  
       {  
             //   /0追加  
             szLogFile[nLogFile-1]   =   0;  
             RegCloseKey(hKey);  
             return   TRUE;  
       }  
      //   失敗  
      RegCloseKey(hKey);  
      return   FALSE;  
  }  

//

 

 

注册表是Windows重要组成部分,注册表记录了大量有关电脑软硬件的信息。注册表中的值通过其名称标识。值名称由与键名相同的字符组成。值本身可以是字符串、二进制数据或者是32位无符号值。在这里我们主要运用以下技巧:

  (一)、预定义的注册表键。注册表包含了几个预定义键:

HKEY_LOCAL_MACHINE 包含描述计算机及其配置的条目。其中包括关于处理器、系统主板、内存和已安装的软件和硬件的信息。   HKEY_CLASSES_ROOT 是与文档类型和 OLE/COM 相关的信息的支持键。这个键是 HKEY_LOCAL_MACHINE的从属键。   HKEY_USERS 用作默认用户首选设置,也作为单个用户的首选设置。   HKEY_CLASSES_USER 是用于当前(登录)用户的相关信息。   HKEY_CURRENT_CONFIG 包含了当前系统配置的信息。   还有一个,一般不会出现,只有配置的局域网后才会有。  

  (二)、CRegKey 类及主要使用和函数说明

所需要头文件:atlbase.h   常用函数 ☆ 打开一个键的函数: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);
      if(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 NT/2000/XP中通过,Windows 9X/Me中请将注册表路径中的Windows NT改为Windows即可实现。 本程序源代码在Windows 2000+VC6.0中通过测试。 本程序源代码示例文件仅能在 Windows NT/2000/XP 下使用,Windows 9X/Me 中请修改后使用。

你可能感兴趣的:(C++)