3

我正在使用 VS2012 WPF Application & Install-shield 2013 LE 来生成安装程序。

安装后我注意到“以管理员身份运行”选项没有出现在desktop icon.

一些用户无法运行应用程序,但他们可以通过进入已安装的目录并右键单击图标以管理员身份运行来运行应用程序。

我检查了这个链接:http://msdn.microsoft.com/en-us/library/ms247046.aspx然后我添加了选项:“使用默认设置嵌入清单”并重新生成了安装程序。但它并没有做出任何改变。

我正在对 Win 7 OS 32bit 进行测试。

当我在资源管理器的上下文菜单中右键单击应用程序图标时,如何启用“以管理员身份运行”选项?

与此问题相同的问题:VS 2010 安装快捷方式文件未显示以管理员身份运行选项

应用程序清单:

<?xml version="1.0" encoding="utf-8"?>
<asmv1:assembly manifestVersion="1.0" xmlns="urn:schemas-microsoft-com:asm.v1" 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">
  <assemblyIdentity version="1.0.0.0" name="MyApplication.app"/>
  <trustInfo xmlns="urn:schemas-microsoft-com:asm.v2">
    <security>
      <requestedPrivileges xmlns="urn:schemas-microsoft-com:asm.v3">
        <!-- 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" />

            Specifying requestedExecutionLevel node will disable file and registry virtualization.
            If you want to utilize File and Registry Virtualization for backward 
            compatibility then delete the requestedExecutionLevel node.
        -->
        <requestedExecutionLevel level="requireAdministrator" uiAccess="false" />
      </requestedPrivileges>
    </security>
  </trustInfo>

  <compatibility xmlns="urn:schemas-microsoft-com:compatibility.v1">
    <application>
      <!-- A list of all Windows versions that this application is designed to work with. 
      Windows will automatically select the most compatible environment.-->

      <!-- If your application is designed to work with Windows Vista, uncomment the following supportedOS node-->
      <supportedOS Id="{e2011457-1546-43c5-a5fe-008deee3d3f0}"></supportedOS>

      <!-- If your application is designed to work with Windows 7, uncomment the following supportedOS node-->
      <supportedOS Id="{35138b9a-5d96-4fbd-8e2d-a2440225f93a}"/>

      <!-- If your application is designed to work with Windows 8, uncomment the following supportedOS node-->
      <supportedOS Id="{4a2f28e3-53b9-4441-ba9c-d69d4a4a6e38}"></supportedOS>

    </application>
  </compatibility>

  <!-- Enable themes for Windows common controls and dialogs (Windows XP and later) -->
   <dependency>
    <dependentAssembly>
      <assemblyIdentity
          type="win32"
          name="Microsoft.Windows.Common-Controls"
          version="6.0.0.0"
          processorArchitecture="*"
          publicKeyToken="6595b64144ccf1df"
          language="*"
        />
    </dependentAssembly>
  </dependency>

</asmv1:assembly>

在此处输入图像描述

在此处输入图像描述

编辑:

我发现InstallShield 2013 LE(限量版)不允许我像这样放置目标方向:"C:\ProgramFiles\TestUtility.exe"。如果目标引用 exe,则“以管理员身份运行”将自动启用。

原来的:

在此处输入图像描述

它应该是这样的:

在此处输入图像描述

所以,InstallShield LE 不允许我改变它。

我必须找到另一种生成安装程序的方法。请问有什么建议吗?

4

2 回答 2

0

我终于找到了为什么没有启用“以管理员身份运行”的原因。当已安装的图标未引用 .exe 时,它​​将不可用。

在此 InstalShield 2013 LE 版本之上不允许更改“目标目录”值。

链接: http: //community.flexerasoftware.com/showthread.php ?206542-Permissions-setting-to-edit-within-directory

引用 .exe 很重要;为什么?用户可以通过 Windows 资源管理器上下文菜单以管理员身份运行应用程序。

我决定使用 WIX 安装程序。

请给我你的FB。

于 2014-02-07T21:15:26.557 回答
0

我发布这个答案后发现了这个。

本质上,您需要禁用 msi 中的“广告链接”。我的答案是来自其他来源的综合答案,它们在 msi 构建模式中执行此操作,从而使其成为您所有项目的单一修复。

它已经过测试并且可以在 64 位 Windows Pro 上运行。

于 2019-03-15T23:54:27.137 回答