0

我正在尝试使用以下代码在 Windows 7 x64 下读取注册表项:

static void ReadRegistryKey(HKEY hkey, TCHAR* path)
{
HKEY hkey2;
TCHAR value[MAX_PATH];
TCHAR data[4096];
const DWORD dataLength = 4096 * sizeof(TCHAR);
const DWORD valueLength = MAX_PATH+1;
DWORD returnval;
DWORD type = 0;

HLOCAL mem = LocalAlloc(LPTR, 260);
char * pc = (char*)mem;
pc++;
wchar_t* pwc = (wchar_t*)pc;
lstrcpy(pwc, path);

// Does key exist?
returnval = RegOpenKeyEx(hkey, pwc, 0 , KEY_READ | KEY_WOW64_64KEY, &hkey2);

if(returnval == ERROR_SUCCESS)
{
    int i = 0;
    while(returnval == ERROR_SUCCESS)
    {
        DWORD actualLength = dataLength;
        DWORD actualValueLength = valueLength;

        returnval = RegEnumValueW( hkey2,
                                    i,
                                    value,
                                    &actualValueLength,
                                    NULL,
                                    &type,
                                    (LPBYTE)data,
                                    &actualLength
                                    );

        if(returnval == ERROR_NO_MORE_ITEMS)
        {
            _tprintf(_T("NO MORE KEYS FOUND in %s\n"), path);
            break;
        }
        if(returnval == ERROR_SUCCESS)
        {
                         // STUFF
        }
   }
}
}

当我使用 KEY_READ | KEY_WOW64_32KEY 我得到存储在 32 位注册表下的值,但是当我使用上面的代码尝试读取“正常”64 位注册表时,我得到错误代码 0x3e6 (ERROR_NOACCESS)

我调用方法的方式:

ReadRegistryKey(HKEY_LOCAL_MACHINE, L"Software\\Microsoft\\Windows\\CurrentVersion\\Run");

如何读取 64 位注册表值?谢谢

4

1 回答 1

1

我认为分配和指针算法pwc是造成问题的原因。直接path传入RegOpenKeyEx函数。

还值得注意的是,如果超过 260 字节,lstrcpy将导致缓冲区溢出。path而是在 Windows 中使用StringCchCopy来提供一个字符串副本,该副本最多只能复制目标缓冲区中可用的字节数。

于 2013-01-08T17:16:09.870 回答