0

我有一个 winform 应用程序来从注册表项中读取值..

所以我知道我必须以管理员身份运行才能这样做。

我有两台win 2003的服务器。一台是32位的,另一台是64位的。

当我在 32 位上运行此应用程序时,我没有问题,它会从注册表中读取值..

但是当我从我的 64 位服务器运行应用程序时,它无法从注册表中读取。

我得到一个

system.null 引用异常

因为我无法读取返回 null 的 reg 键的根。

我也放了一个清单文件,但它也不起作用..

任何帮助将不胜感激...谢谢..

这是我的清单文件:

<?xml version="1.0" encoding="utf-8"?>
<asmv1:assembly manifestVersion="1.0" xsi:schemaLocation="urn:schemas-microsoft-com:asm.v1 assembly.adaptive.xsd" xmlns:asmv3="urn:schemas-microsoft-com:asm.v3" xmlns:dsig="http://www.w3.org/2000/09/xmldsig#" xmlns="urn:schemas-microsoft-com:asm.v2" xmlns:asmv1="urn:schemas-microsoft-com:asm.v1" xmlns:asmv2="urn:schemas-microsoft-com:asm.v2" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:co.v1="urn:schemas-microsoft-com:clickonce.v1">
 <asmv1:assemblyIdentity version="1.0.0.31" name="FileShareMgmt.exe" publicKeyToken="0000000000000000" language="neutral" processorArchitecture="msil" type="win32" />
<application />
<entryPoint>
<assemblyIdentity name="FileShareMgmt" version="1.0.0.0" language="neutral" processorArchitecture="msil" />
<commandLine file="FileShareMgmt.exe" parameters="" />
</entryPoint>
<trustInfo>
<security>
  <applicationRequestMinimum>
    <PermissionSet class="System.Security.PermissionSet" version="1"  Unrestricted="true" ID="Custom" SameSite="site" />
    <defaultAssemblyRequest permissionSetReference="Custom" />
  </applicationRequestMinimum>
  <requestedPrivileges xmlns="urn:schemas-microsoft-com:asm.v3">       
<requestedExecutionLevel  level="highestAvailable" uiAccess="false" />
    <!-- UAC Manifest Options
        If you want to change the Windows User Account Control level replace the 
        requestedExecutionLevel node with one of the following.

    <requestedExecutionLevel  level="asInvoker" uiAccess="false" />
    <requestedExecutionLevel  level="requireAdministrator" uiAccess="false" />
    <requestedExecutionLevel  level="highestAvailable" uiAccess="false" />

        If you want to utilize File and Registry Virtualization for backward 
        compatibility then delete the requestedExecutionLevel node.
    -->     
  </requestedPrivileges>
</security>
</trustInfo>

这不是完整的清单,因为我认为这里不需要显示...

4

1 回答 1

1

您是否确认您尝试读取的密钥存在于 64 位系统上?

64 位系统的路径可能不同:http: //support.microsoft.com/kb/896459

如果您的注册表项包含文本“WOW6432node”,那就是 32 位版本。64 位版本可能相同,只是路径的一部分不存在。

这个问题可能是相关的:为什么 OpenSubKey() 在我的 Windows 7 64 位系统上返回 null?

于 2011-07-08T15:55:48.763 回答