读写windows注册表

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了读写windows注册表相关的知识,希望对你有一定的参考价值。

  最近有在做一写读写配置文件的项目内容,了解到注册表也可以写配置,于是顺便连接一下读写注册表的内容。

MFC上读写注册表

MFC的
CWinApp 类提供了很容易的注册表访问函数~~以前从来没注意过~~还到处找读写注册表的办法~~ -_-! 看下面几个成员函数~ 

SetRegistryKey Causes application settings to be stored in the registry instead of .INI files.

SetRegistryKey 这个函数功能是设置MFC程序的注册表访问键,并把读写 ini 文件的成员函数映射到读写注册表。只要调用一下 SetRegistryKey 并指定注册表键值,那么下面6个成员函数,就被映射到进行注册表读取了~

WriteProfileBinary Writes binary data to an entry in the application‘s .INI file.
WriteProfileInt Writes an integer to an entry in the application‘s .INI file.
WriteProfileString Writes a string to an entry in the application‘s .INI file.

GetProfileBinary Retrieves binary data from an entry in the application‘s .INI file.
GetProfileInt Retrieves an integer from an entry in the application‘s .INI file.
GetProfileString Retrieves a string from an entry in the application‘s .INI file.

MSDN上面写上面6个函数是写到INI文件的。所以俺就忽略了其访问注册表的功能。无意中看了其MFC实现才有所了解。

例子如下:
SetRegistryKey(_T("boli‘s app")); //这里是准备在注册表HKEY_CURRENT_USER\\\\software 下面生成一个boli‘s app 分支~为什么说是准备呢?因为如果不调用相关函数,如上面提到的6个函数,它是不会真正读写注册表的。具体本文最最下面的MFC实现摘录。
CString strUserName,strPassword;
WriteProfileString("LogInfo","UserName",strUserName); //向注册表HKEY_CURRENT_USER\\\\software\\\\boli‘s app\\\\LogInfo\\\\分支下写入 UserName 字符串行键值~
WriteProfileString("LogInfo","Password",strPassword);//同上~

 strUserName = GetProfileString("LogInfo","UserName");// 这里是读取HKEY_CURRENT_USER\\\\software\\\\boli‘s app\\\\LogInfo\\\\分支下的 UserName 字符串键值到 strUserName~
 strPassword =  GetProfileString("LogInfo","Password"); 

如果不是在CWinApp 派生的类中读写注册表,可以直接用:
 strUserName = theApp.GetProfileString("LogInfo","UserName");
 strPassword = theApp.GetProfileString("LogInfo","Password");
或 
 strUserName = AfxGetApp()->GetProfileString("LogInfo","UserName");
条条大路通罗马。



看看MFC的代码吧~~SDK高手们不屑MFC,但有时候看看MFC的代码会到学习SDK,windows api有很大的帮助~ :P
////////////////////////////////////////////////////////////////////////////
// CWinApp Settings Helpers

 

#ifdef AFX_INIT_SEG
#pragma code_seg(AFX_INIT_SEG)
#endif

void CWinApp::SetRegistryKey(LPCTSTR lpszRegistryKey)
{
     ASSERT(m_pszRegistryKey == NULL);
     ASSERT(lpszRegistryKey != NULL);
     ASSERT(m_pszAppName != NULL);

     BOOL bEnable = AfxEnableMemoryTracking(FALSE);
     free((void*)m_pszRegistryKey);
     m_pszRegistryKey = _tcsdup(lpszRegistryKey);
     free((void*)m_pszProfileName);
     m_pszProfileName = _tcsdup(m_pszAppName);
     AfxEnableMemoryTracking(bEnable);
}

void CWinApp::SetRegistryKey(UINT nIDRegistryKey)
{
     ASSERT(m_pszRegistryKey == NULL);

     TCHAR szRegistryKey[256];
     VERIFY(AfxLoadString(nIDRegistryKey, szRegistryKey));
     SetRegistryKey(szRegistryKey);
}

// returns key for HKEY_CURRENT_USER\\"Software"\\RegistryKey\\ProfileName
// creating it if it doesn‘t exist
// responsibility of the caller to call RegCloseKey() on the returned HKEY
HKEY CWinApp::GetAppRegistryKey()
{
     ASSERT(m_pszRegistryKey != NULL);
     ASSERT(m_pszProfileName != NULL);

     HKEY hAppKey = NULL;
     HKEY hSoftKey = NULL;
     HKEY hCompanyKey = NULL;
     if (RegOpenKeyEx(HKEY_CURRENT_USER, _T("software"), 0, KEY_WRITE|KEY_READ,
      &hSoftKey) == ERROR_SUCCESS)
     {
          DWORD dw;
          if (RegCreateKeyEx(hSoftKey, m_pszRegistryKey, 0, REG_NONE,
           REG_OPTION_NON_VOLATILE, KEY_WRITE|KEY_READ, NULL,
           &hCompanyKey, &dw) == ERROR_SUCCESS)
             {
                   RegCreateKeyEx(hCompanyKey, m_pszProfileName, 0, REG_NONE,
                    REG_OPTION_NON_VOLATILE, KEY_WRITE|KEY_READ, NULL,
                    &hAppKey, &dw);
              }
 }
 if (hSoftKey != NULL)
  RegCloseKey(hSoftKey);
 if (hCompanyKey != NULL)
  RegCloseKey(hCompanyKey);

 return hAppKey;
}

// returns key for:
//      HKEY_CURRENT_USER\\"Software"\\RegistryKey\\AppName\\lpszSection
// creating it if it doesn‘t exist.
// responsibility of the caller to call RegCloseKey() on the returned HKEY
HKEY CWinApp::GetSectionKey(LPCTSTR lpszSection)
{
     ASSERT(lpszSection != NULL);

     HKEY hSectionKey = NULL;
     HKEY hAppKey = GetAppRegistryKey();
     if (hAppKey == NULL)
      return NULL;

     DWORD dw;
     RegCreateKeyEx(hAppKey, lpszSection, 0, REG_NONE,
      REG_OPTION_NON_VOLATILE, KEY_WRITE|KEY_READ, NULL,
          &hSectionKey, &dw);
     RegCloseKey(hAppKey);
     return hSectionKey;
}

UINT CWinApp::GetProfileInt(LPCTSTR lpszSection, LPCTSTR lpszEntry,
 int nDefault)
{
     ASSERT(lpszSection != NULL);
     ASSERT(lpszEntry != NULL);
     if (m_pszRegistryKey != NULL) // use registry
     {
          HKEY hSecKey = GetSectionKey(lpszSection);
          if (hSecKey == NULL)
           return nDefault;
          DWORD dwValue;
          DWORD dwType;
          DWORD dwCount = sizeof(DWORD);
          LONG lResult = RegQueryValueEx(hSecKey, (LPTSTR)lpszEntry, NULL, &dwType,
           (LPBYTE)&dwValue, &dwCount);
          RegCloseKey(hSecKey);
          if (lResult == ERROR_SUCCESS)
          {
               ASSERT(dwType == REG_DWORD);
               ASSERT(dwCount == sizeof(dwValue));
               return (UINT)dwValue;
             }
             return nDefault;
   }
 else
 {
          ASSERT(m_pszProfileName != NULL);
          return ::GetPrivateProfileInt(lpszSection, lpszEntry, nDefault,
           m_pszProfileName);
     }

}

CString CWinApp::GetProfileString(LPCTSTR lpszSection, LPCTSTR lpszEntry,
 LPCTSTR lpszDefault)
{
 ASSERT(lpszSection != NULL);
 ASSERT(lpszEntry != NULL);
 if (m_pszRegistryKey != NULL)
 {
  HKEY hSecKey = GetSectionKey(lpszSection);
  if (hSecKey == NULL)
   return lpszDefault;
  CString strValue;
  DWORD dwType, dwCount;
  LONG lResult = RegQueryValueEx(hSecKey, (LPTSTR)lpszEntry, NULL, &dwType,
   NULL, &dwCount);
  if (lResult == ERROR_SUCCESS)
  {
   ASSERT(dwType == REG_SZ);
   lResult = RegQueryValueEx(hSecKey, (LPTSTR)lpszEntry, NULL, &dwType,
    (LPBYTE)strValue.GetBuffer(dwCount/sizeof(TCHAR)), &dwCount);
   strValue.ReleaseBuffer();
  }
  RegCloseKey(hSecKey);
  if (lResult == ERROR_SUCCESS)
  {
   ASSERT(dwType == REG_SZ);
   return strValue;
  }
  return lpszDefault;
 }
 else
 {
  ASSERT(m_pszProfileName != NULL);

  if (lpszDefault == NULL)
   lpszDefault = _T(""); // don‘t pass in NULL
  TCHAR szT[4096];
  DWORD dw = ::GetPrivateProfileString(lpszSection, lpszEntry,
   lpszDefault, szT, _countof(szT), m_pszProfileName);
  ASSERT(dw < 4095);
  return szT;
 }
}

BOOL CWinApp::GetProfileBinary(LPCTSTR lpszSection, LPCTSTR lpszEntry,
 BYTE** ppData, UINT* pBytes)
{
 ASSERT(lpszSection != NULL);
 ASSERT(lpszEntry != NULL);
 ASSERT(ppData != NULL);
 ASSERT(pBytes != NULL);
 *ppData = NULL;
 *pBytes = 0;
 if (m_pszRegistryKey != NULL)
 {
  HKEY hSecKey = GetSectionKey(lpszSection);
  if (hSecKey == NULL)
   return FALSE;

  DWORD dwType, dwCount;
  LONG lResult = RegQueryValueEx(hSecKey, (LPTSTR)lpszEntry, NULL, &dwType,
   NULL, &dwCount);
  *pBytes = dwCount;
  if (lResult == ERROR_SUCCESS)
  {
   ASSERT(dwType == REG_BINARY);
   *ppData = new BYTE[*pBytes];
   lResult = RegQueryValueEx(hSecKey, (LPTSTR)lpszEntry, NULL, &dwType,
    *ppData, &dwCount);
  }
  RegCloseKey(hSecKey);
  if (lResult == ERROR_SUCCESS)
  {
   ASSERT(dwType == REG_BINARY);
   return TRUE;
  }
  else
  {
   delete [] *ppData;
   *ppData = NULL;
  }
  return FALSE;
 }
 else
 {
  ASSERT(m_pszProfileName != NULL);

  CString str = GetProfileString(lpszSection, lpszEntry, NULL);
  if (str.IsEmpty())
   return FALSE;
  ASSERT(str.GetLength()%2 == 0);
  INT_PTR nLen = str.GetLength();
  *pBytes = UINT(nLen)/2;
  *ppData = new BYTE[*pBytes];
  for (int i=0;i<nLen;i+=2)
  {
   (*ppData)[i/2] = (BYTE)
    (((str[i+1] - ‘A‘) << 4) + (str[i] - ‘A‘));
  }
  return TRUE;
 }
}

#ifdef AFX_CORE3_SEG
#pragma code_seg(AFX_CORE3_SEG)
#endif

BOOL CWinApp::WriteProfileInt(LPCTSTR lpszSection, LPCTSTR lpszEntry,
 int nValue)
{
 ASSERT(lpszSection != NULL);
 ASSERT(lpszEntry != NULL);
 if (m_pszRegistryKey != NULL)
 {
  HKEY hSecKey = GetSectionKey(lpszSection);
  if (hSecKey == NULL)
   return FALSE;
  LONG lResult = RegSetValueEx(hSecKey, lpszEntry, NULL, REG_DWORD,
   (LPBYTE)&nValue, sizeof(nValue));
  RegCloseKey(hSecKey);
  return lResult == ERROR_SUCCESS;
 }
 else
 {
  ASSERT(m_pszProfileName != NULL);

  TCHAR szT[16];
  wsprintf(szT, _T("%d"), nValue);
  return ::WritePrivateProfileString(lpszSection, lpszEntry, szT,
   m_pszProfileName);
 }
}

BOOL CWinApp::WriteProfileString(LPCTSTR lpszSection, LPCTSTR lpszEntry,
   LPCTSTR lpszValue)
{
 ASSERT(lpszSection != NULL);
 if (m_pszRegistryKey != NULL)
 {
  LONG lResult;
  if (lpszEntry == NULL) //delete whole section
  {
   HKEY hAppKey = GetAppRegistryKey();
   if (hAppKey == NULL)
    return FALSE;
   lResult = ::RegDeleteKey(hAppKey, lpszSection);
   RegCloseKey(hAppKey);
  }
  else if (lpszValue == NULL)
  {
   HKEY hSecKey = GetSectionKey(lpszSection);
   if (hSecKey == NULL)
    return FALSE;
   // necessary to cast away const below
   lResult = ::RegDeleteValue(hSecKey, (LPTSTR)lpszEntry);
   RegCloseKey(hSecKey);
  }
  else
  {
   HKEY hSecKey = GetSectionKey(lpszSection);
   if (hSecKey == NULL)
    return FALSE;
   lResult = RegSetValueEx(hSecKey, lpszEntry, NULL, REG_SZ,
    (LPBYTE)lpszValue, (lstrlen(lpszValue)+1)*sizeof(TCHAR));
   RegCloseKey(hSecKey);
  }
  return lResult == ERROR_SUCCESS;
 }
 else
 {
  ASSERT(m_pszProfileName != NULL);
  ASSERT(lstrlen(m_pszProfileName) < 4095); // can‘t read in bigger
  return ::WritePrivateProfileString(lpszSection, lpszEntry, lpszValue,
   m_pszProfileName);
 }
}

BOOL CWinApp::WriteProfileBinary(LPCTSTR lpszSection, LPCTSTR lpszEntry,
 LPBYTE pData, UINT nBytes)
{
 ASSERT(lpszSection != NULL);
 if (m_pszRegistryKey != NULL)
 {
  LONG lResult;
  HKEY hSecKey = GetSectionKey(lpszSection);
  if (hSecKey == NULL)
   return FALSE;
  lResult = RegSetValueEx(hSecKey, lpszEntry, NULL, REG_BINARY,
   pData, nBytes);
  RegCloseKey(hSecKey);
  return lResult == ERROR_SUCCESS;
 }

 // convert to string and write out
 LPTSTR lpsz = new TCHAR[nBytes*2+1];
 UINT i;
 for (i = 0; i < nBytes; i++)
 {
  lpsz[i*2] = (TCHAR)((pData[i] & 0x0F) + ‘A‘); //low nibble
  lpsz[i*2+1] = (TCHAR)(((pData[i] >> 4) & 0x0F) + ‘A‘); //high nibble
 }
 lpsz[i*2] = 0;

 ASSERT(m_pszProfileName != NULL);

 BOOL bResult = WriteProfileString(lpszSection, lpszEntry, lpsz);
 delete[] lpsz;
 return bResult;
}

 

 

 
  1. #include <iostream>    
  2. #include <algorithm>    
  3. #include <cmath>    
  4. #include <vector>    
  5. #include <string>    
  6. #include <cstring>  
  7. #include <atlbase.h>  
  8. #include <Windows.h>  
  9. #pragma warning(disable:4996)    
  10. using namespace std;  
  11.   
  12. void read_dword()//读取操作表,其类型为DWORD  
  13. {  
  14.     HKEY hKEY;//定义有关的键,在查询结束时关闭  
  15.     //打开与路径data_Set相关的hKEY  
  16.   
  17.     LPCTSTR data_set = _T("Software\\\\Chicony\\\\Lenovo1");   
  18.       
  19.     //访问注册表,hKEY则保存此函数所打开的键的句柄  
  20.     if (ERROR_SUCCESS == ::RegOpenKeyEx(HKEY_CURRENT_USER, data_set, 0, KEY_READ, &hKEY))  
  21.     {  
  22.         DWORD dwValue;//长整型数据,如果是字符串数据用char数组  
  23.         DWORD dwSize = sizeof(DWORD);  
  24.         DWORD dwType = REG_DWORD;  
  25.   
  26.         if (::RegQueryValueEx(hKEY, _T("123"), 0, &dwType, (LPBYTE)&dwValue, &dwSize) != ERROR_SUCCESS)  
  27.         {  
  28.             cout << "错误:无法查询有关的注册表信息" << endl;  
  29.         }  
  30.   
  31.         cout << dwValue << endl;  
  32.     }  
  33.     ::RegCloseKey(hKEY);  
  34. }  
  35.   
  36. void read_reg_sz()//读取操作表,其类型为REG_SZ  
  37. {  
  38.     HKEY hkey;  
  39.     LPCTSTR data_set = _T("Software\\\\Chicony\\\\Lenovo1");  
  40.   
  41.     if (ERROR_SUCCESS == ::RegOpenKeyEx(HKEY_CURRENT_USER, data_set, 0, KEY_READ, &hkey))  
  42.     {  
  43.         char dwValue[256];  
  44.         DWORD dwSzType = REG_SZ;  
  45.         DWORD dwSize = sizeof(dwValue);  
  46.         if (::RegQueryValueEx(hkey, _T("wangchong"), 0, &dwSzType, (LPBYTE)&dwValue, &dwSize) != ERROR_SUCCESS)  
  47.         {  
  48.             cout << "无法查询有关的注册表信息" << endl;  
  49.         }  
  50.         cout << dwValue<< endl;  
  51.     }  
  52.     ::RegCloseKey(hkey);  
  53. }  
  54.   
  55. void write_dword()//在\\Software\\\\Chicony\\\\Lenovo1文件夹下写入一个test111的子键,设置其名称为Name,其值为6  
  56. {  
  57.     HKEY hkey;//定义有关的hkey,在查询结束时要关闭  
  58.     HKEY hTempKey;  
  59.       
  60.     DWORD dwValue = 6;  
  61.     DWORD dwSize = sizeof(DWORD);  
  62.     DWORD dwType = REG_DWORD;  
  63.   
  64.     LPCTSTR data_set= _T("Software\\\\Chicony\\\\Lenovo1");  
  65.     if (ERROR_SUCCESS == RegOpenKeyEx(HKEY_CURRENT_USER, data_set, 0, KEY_SET_VALUE, &hkey))  
  66.     {  
  67.         if (ERROR_SUCCESS == ::RegCreateKey(hkey, _T("test111"), &hTempKey))  
  68.         {  
  69.             if (ERROR_SUCCESS != ::RegSetValueEx(hTempKey, _T("Name"), 0, REG_DWORD, (CONST BYTE*)&dwValue, sizeof(DWORD)))  
  70.             {  
  71.                 cout <<"写入注册表失败"<< endl;  
  72.             }  
  73.         }  
  74.     }  
  75.     ::RegCloseKey(hkey);  
  76. }  
  77.   
  78. void write_reg_sz()  
  79. {  
  80.     HKEY hkey;  
  81.     HKEY hTempKey;     
  82.     char m_name_set[256]="China";  
  83.   
  84.     DWORD len = strlen(m_name_set) + 1;  
  85.     LPCTSTR data_set = _T("Software\\\\Chicony\\\\Lenovo1");  
  86.     if (ERROR_SUCCESS == ::RegOpenKeyEx(HKEY_CURRENT_USER, data_set, 0, KEY_SET_VALUE, &hkey))  
  87.     {  
  88.         if (ERROR_SUCCESS == ::RegCreateKey(hkey,_T("test1112"),&hTempKey))  
  89.         {  
  90.             if (ERROR_SUCCESS!=::RegSetValueEx(hTempKey,_T("Name"),0,REG_SZ,(const BYTE*)m_name_set,len))  
  91.             {  
  92.                 cout << "写入错误" << endl;  
  93.             }  
  94.         }  
  95.     }  
  96.     ::RegCloseKey(hkey);  
  97. }  
  98.   
  99. void write_binary()  
  100. {  
  101.     HKEY hkey;  
  102.     HKEY hTempKey;  
  103.     BYTE m_name[10];  
  104.     memset(m_name, 0, sizeof(m_name));  
  105.     m_name[0] = 0xff;  
  106.     m_name[1] = 0xac;  
  107.     m_name[2] = 0x05;  
  108.     m_name[3] = 0x4e;  
  109.   
  110.     LPCTSTR data_set= _T("Software\\\\Chicony\\\\Lenovo1");  
  111.     if (ERROR_SUCCESS == ::RegOpenKeyEx(HKEY_CURRENT_USER, data_set, 0, KEY_SET_VALUE, &hkey))  
  112.     {  
  113.         if (ERROR_SUCCESS==::RegCreateKey(hkey,_T("test111"),&hTempKey))  
  114.         {  
  115.             if (ERROR_SUCCESS != ::RegSetValueEx(hTempKey, _T("Name"), 0, REG_BINARY, (unsigned char *)m_name, 5))  
  116.             {  
  117.                 cout << "写入错误" << endl;  
  118.             }  
  119.         }  
  120.     }  
  121.     ::RegCloseKey(hkey);  
  122. }  
  123.   
  124. void delete_value()  
  125. {  
  126.     HKEY hkey;  
  127.     LPCTSTR data_set = _T("Software\\\\Chicony\\\\Lenovo1\\\\test1112");  
  128.   
  129.     if (ERROR_SUCCESS == ::RegOpenKeyEx(HKEY_CURRENT_USER, data_set, 0, KEY_SET_VALUE, &hkey))  
  130.     {  
  131.         if (ERROR_SUCCESS != ::RegDeleteValue(hkey, _T("Name")))  
  132.         {  
  133.             cout << "删除错误" << endl;  
  134.         }  
  135.     }  
  136.     ::RegCloseKey(hkey);  
  137. }  
  138.   
  139. void delete_key()  
  140. {  
  141.     HKEY hkey;  
  142.     LPCTSTR data_set = _T("Software\\\\Chicony\\\\Lenovo1");  
  143.   
  144.     if (ERROR_SUCCESS == ::RegOpenKeyEx(HKEY_CURRENT_USER, data_set, 0, KEY_SET_VALUE, &hkey))  
  145.     {  
  146.         if (ERROR_SUCCESS != ::RegDeleteKey(hkey,"test1112"))  
  147.         {  
  148.             cout << "删除错误" << endl;  
  149.         }  
  150.     }  
  151.     ::RegCloseKey(hkey);  
  152. }  
  153.   
  154. int main()  
  155. {      
  156.     read_dword();  
  157.     read_reg_sz();  
  158.     write_reg_sz();  
  159.     write_binary();  
  160.     delete_value();  
  161.     delete_key();  
  162.     system("pause");    
  163.     return 0;  
  164. }  
  165. 技术分享

     

 技术分享

 

以上是关于读写windows注册表的主要内容,如果未能解决你的问题,请参考以下文章

注册表与木马——注册表读写

python 基础注册(文件读写练习)

QSettings 类

C#中读写INI文件

QSettings使用方法

Delphi 读写注册表