如何从32位代码启动64位的Windows进程?

时间:2008-10-02 13:37:47

标签: c++ winapi 64-bit registry

要在写入HKLM注册表配置单元时在Vista中弹出UAC对话框,我们选择不使用Win32注册表API,因为缺少Vista权限时,我们需要使用管理员权限重新启动整个应用程序。相反,我们这样做:

ShellExecute(hWnd, "runas" /* display UAC prompt on Vista */, windir + "\\Reg", "add HKLM\\Software\\Company\\KeyName /v valueName /t REG_MULTI_TZ /d ValueData", NULL, SW_HIDE);

这个解决方案工作正常,除了我们的应用程序是一个32位,它运行REG.EXE命令,因为它将是一个使用WOW兼容层的32位应用程序! :(如果REG.EXE是从命令行运行的,它在64位模式下运行正常。这很重要,因为如果它作为32位应用程序运行,由于{{{{},注册表项将最终位于错误的位置3}}

那么有没有办法从32位应用程序以编程方式启动64位应用程序,而不是像使用其父级32位进程那样使用WOW64子系统运行(即任务管理器中的“*”后缀) ?

4 个答案:

答案 0 :(得分:12)

试试这个(来自32位进程):

> %WINDIR%\sysnative\reg.exe query ...

(找到here)。

答案 1 :(得分:8)

是否运行32位或64位本机(非托管)程序完全取决于可执行文件。在{C:\ Windows \ System32(64位)和C:\ Windows \ SysWOW64(32位)中有两个reg.exe副本。因为您没有指定路径,所以您将获得PATH环境变量中首先出现的内容,这是32位进程的32位版本。

您应该将此函数分解为单独的程序或COM对象,并使用清单标记程序,或使用COM elevation moniker启动COM对象。

答案 2 :(得分:2)

您是否考虑过创建一个小型“帮助程序”应用程序来为您更新注册表?如果您将其编译为64位并包含一个表明它需要管理员权限的清单,那么它将为您提供两个基础。

有一些API可以检测您正在运行的操作系统的“位数”,因此您可以编辑RegistryUpdate32.exe和RegistryUpdate64.exe并调用相关的。

答案 3 :(得分:1)

我作为自己的解决方案做的一件事是PInvoke禁用重定向:

http://msdn.microsoft.com/en-us/library/windows/desktop/aa365744(v=vs.85).aspx

您可以随时重新开启。