C++ 访问注册表(64位系统)

xiaotu123 · · 1387 次点击 · 开始浏览    置顶
这是一个创建于 的主题,其中的信息可能已经有所发展或是发生改变。

1、问题描述 HKEY_LOCAL_MACHINE\Software\Wow6432Node\XXXX中“Wow6432Node”在32位Windows上则不存在,怎么统一处理? 2、问题分析 Either KEY_WOW64_32KEY or KEY_WOW64_64KEY can be specified. If both flags are specified, the function fails with ERROR_INVALID_PARAMETER. Windows Server 2008, Windows Vista, Windows Server 2003, and Windows XP: If both flags are specified, the function’s behavior is undefined. 指示 64 位注册表上的Windows应在 32 位注册表视图上运行。 此标志被 32 位或 32 位Windows。 有关详细信息,请参阅 访问备用注册表视图。 KEY _ WOW64 _ 64KEY (0x0100) 指示 64 位注册表上的Windows应在 64 位注册表视图上运行。 此标志被 32 位或 32 位Windows。 有关详细信息,请参阅 访问备用注册表视图。此标志必须与此表中查询或访问注册表值的其他标志结合使用 OR 运算符。Windows 2000: 不支持此标志。此标志必须与此表中查询或访问注册表值的其他标志结合使用 OR 运算符。Windows 2000: 不支持此标志。 不要尝试Wow6432Node,因为32位Windows没有。 64bit系统的注册表分32 位注册表项和64位注册表项两部分。 在64bit系统下,通过regedit中查看到指定路径下的注册表项均为64位注册表项,而32位注册表项被重定位到:HKEY_LOCAL_MACHINE\Software\WOW6432Node 应用程序操作注册表的时候也分32bit方式和64bit方式。 运行于64bit系统下的32bit应用程序默认操作32位注册表项(即被重定向到WOW6432Node下的子项);而64bit应用程序才是操作的直观子项。 比如,同在64bit系统下,使用如下代码访问注册表: ::RegOpenKeyEx(HKEY_LOCAL_MACHINE, _T("Software\\Sobey\\MPC "), 0, KEY_ALL_ACCESS, &hKey) 如果应用程序为32bit子系统,那么实际访问的注册表位置为(默认操作): HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Sobey\MPC 而如果应用程序为64bit子系统,那么实际访问的注册表位置将会是(默认操作): HKEY_LOCAL_MACHINE\SOFTWARE\Sobey\MPC 3、程序编写 编程过程中,可以使用KEY_WOW64_64KEY和KEY_WOW64_32KEY明确的指定操作64位注册表项或者32位注册表项。 在32bit子系统应用程序中,可以用如下方式明确指定访问64bit注册表项,程序代码: ::RegOpenKeyEx(HKEY_LOCAL_MACHINE, _T("Software\\Sobey\\MPC "), 0, KEY_ALL_ACCESS | KEY_WOW64_64KEY, &hKey) 注意关键字KEY_WOW64_64KEY;这种方式写入的注册表项将会确切的位于位置: HKEY_LOCAL_MACHINE\SOFTWARE\Sobey\MPC 在64bit子系统应用程序中,可以用如下方式明确指定访问32bit注册表项,程序代码: ::RegOpenKeyEx(HKEY_LOCAL_MACHINE, _T("Software\\Sobey\\MPC\\Test"), 0, KEY_ALL_ACCESS | KEY_WOW64_32KEY, &hKey) 注意关键字KEY_WOW64_32KEY, 这种方式写入的注册表项将会确切的位于位置: HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Sobey\MPC(使用regedit工具软件对应的位置)。 4、注意事项 4.1 使用HKEY_CURRENT_USER 上述说明只针对HKEY_LOCAL_MACHINE主键而言,HKEY_CURRENT_USER主键下没有类似情况;当访问HKEY_CURRENT_USER主键时,明确指定KEY_WOW64_64KEY和KEY_WOW64_32KEY标志也没有意义。 总之,尽可能使用HKEY_CURRENT_USER主键来保存用户配置吧。 4.2 使用HKEY_LOCAL_MACHINE 在64位电脑上操作以HKEY_LOCAL_MACHINE主键的时候,首先保证一下几项: 请用户以管理员权限或Administrator管理员账户来执行应用程序。 默认情况下,在64位系统上,32位程序访问32位注册表,64位程序访问64位注册表。 32位程序需要访问64位注册表,需要添加KEY_WOW64_64KEY标志; 64位程序需要访问32位注册表,需要添加KEY_WOW64_32KEY标志; 如未指定则按照默认的处理。目前64位系统上的32位注册表位于HKCU/HKLM下的\SOFTWARE\Wow6432Node,但不要直接访问该键。 4.3 使用HKEY_CLASSES_ROOT 注意字符集。VS新版都默认Unicode字符集。 HKEY_CLASSES_ROOT主键虽然不区分32位和64位注册表,但需要管理员权限才能进行创建子项操作。此外读写操作不需要管理员权限。 4.4 权限 一般不要使用KEY_ALL_ACCESS。对于只读访问,指定KEY_READ,对于读/写KEY_READ|KEY_WRITE。如果指定的特权超出了所需的数量,则最终可能一无所获,或者迫使用户始终以管理员权限运行程序。通常,它是一种通用的安全性方法,称为"最小特权原则"。 当然将KEY_ALL_ACCESS改为KEY_QUERY_VALUE,应用程序就能在所有的平台上正常运行了。

有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1387 次点击  
加入收藏 微博
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传