我不能使用RegOpenKeyEx

时间:2011-06-12 15:15:22

标签: c++ registry

我在阅读注册表时遇到问题。 此函数查找注册表路径中的条目数。它完美运行,我测试过它:

void findNumberEntries(registryTest &INSTALLKEY) {

char buffer[50];
char size = sizeof(buffer);
int index = 0;

if(RegOpenKeyEx(INSTALLKEY.hKey,(LPTSTR)(INSTALLKEY.regpath.c_str()),0,KEY_ALL_ACCESS,&INSTALLKEY.hKey) == ERROR_SUCCESS) {     

    DWORD readEntry;

    do {
        readEntry = RegEnumValue(INSTALLKEY.hKey,index,(LPTSTR)buffer,(LPDWORD)&size,NULL,NULL,NULL,NULL);
        index++;
    }
    while(readEntry != ERROR_NO_MORE_ITEMS);
}
INSTALLKEY.number = index;
RegCloseKey(INSTALLKEY.hKey);
}

现在,主要功能:

std::string regpath32 = "SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run\\";
struct registryTest {
HKEY hKey;
std::string regpath;
int number;
};

registryTest INSTALLKEY = {HKEY_LOCAL_MACHINE, regpath32};
findNumberEntries(INSTALLKEY);
printf("%d\n",INSTALLKEY.number);
system("PAUSE");
//until here everything works as it should

HKEY hKey = INSTALLKEY.hKey;
std::string regpath = INSTALLKEY.regpath;
char buffer[50];
char size = sizeof(buffer);
std::string bufferString;
DWORD regOpen = RegOpenKeyEx(INSTALLKEY.hKey,(LPTSTR)INSTALLKEY.regpath.c_str(),0,KEY_READ,&INSTALLKEY.hKey);
if(regOpen == ERROR_SUCCESS) //this is the part that fails.
{
    printf("Registry Key was successfully opened\n");
}
else
{
    printf("Unable to open registry key\n");
    LPVOID message; 
    FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS,
        NULL, GetLastError(), NULL,(LPTSTR) &message, 0, NULL );
    MessageBox(NULL,(LPCTSTR)message,"ERROR",MB_OK|MB_ICONINFORMATION);
}

...rest of the code

我总是得到“无法打开注册表”,我收到的错误消息是“没有更多文件”。有什么问题??

3 个答案:

答案 0 :(得分:2)

您的问题是,当您第一次打开注册表项时,将其分配给结构的hkey-member。所以第二次这个hkey不再包含原始的basekey了。

改变:

  

DWORD regOpen =   RegOpenKeyEx(INSTALLKEY.hKey,(LPTSTR)INSTALLKEY.regpath.c_str(),0,KEY_READ,&安培; INSTALLKEY.hKey);

进入

  

DWORD regOpen = RegOpenKeyEx(   HKEY_LOCAL_MACHINE   ,(LPTSTR)INSTALLKEY.regpath.c_str(),0,KEY_READ,&安培; INSTALLKEY.hKey);

或更改此内容:

void findNumberEntries( registryTest &INSTALLKEY)   
{
  char buffer[50];
  char size = sizeof(buffer); 
  int index = 0; 
  HKEY hkOpen = 0; // can't use INVALID_HANDLE_VALUE for HKEY's;

  if (RegOpenKeyEx( INSTALLKEY.hKey ,(LPTSTR)(INSTALLKEY.regpath.c_str())
                   ,0,&hkOpen ) == ERROR_SUCCESS) 
  {
      // You should use RegQueryInfoKey for below code !
      DWORD readEntry;      
      do {
         readEntry = RegEnumValue( hkOpen ,index,(LPTSTR)buffer
                       ,(LPDWORD size,NULL,NULL,NULL,NULL);
         index++;
     }
    while(readEntry != ERROR_NO_MORE_ITEMS); }
    INSTALLKEY.number = index;
    RegCloseKey( hkOpen );
 }

答案 1 :(得分:0)

您可能还需要在第二个调用中指定KEY_ALL_ACCESS,而不是仅在第一个调用中指定{{1}}。在Win7 64位上你可能会遇到注册表重定向疯狂(http://msdn.microsoft.com/en-us/library/aa384232%28VS.85%29.aspx)。

编辑:啊,你可能只是得到一个ERROR_CANTWRITE(错误代码5)。您可以忽略它并查看它是否仍然有效。

答案 2 :(得分:0)

在Windows 7 64位上,您很可能通过Registry Virtualization重定向。您可以通过调用RegQueryReflectionKey确定要重定向的密钥。

如果您修改代码以输出返回的实际整数值而不是通用的“无法打开密钥”,那么它将会有所帮助。例如,

    long n = RegOpenKeyEx(HKEY_LOCAL_MACHINE,TEXT("\\SOFTWARE"),
                      0,KEY_QUERY_VALUE, &hk );
    if ( n == ERROR_SUCCESS ) {
        cout << "OK" << endl;
    }
    else {
        cout << "Failed with value " << n << endl;
    }