VS2012 程序以管理员身份运行

3 篇文章 0 订阅
最近写的一个程序,无论如何怎么都不能在其他电脑上普通用户、安装在C盘下的文件进行读写(包括数据库)、以及注册表在操作


按照网上的说法,操作ClickOnce。结果毫无结果,根本没有任何提示。这让我很蛋疼。莫非我的VS或者电脑有问题?


后来尝试发现,不直接使用VS自带的ClickOnce设置(项目-》属性-》安全性-》选中启用ClickOnce安全性-》修改自动生成的app.manifest 内容requestedExecutionLevel)


而是自己在项目上新建一个程序清单(项目-》添加新建项-》应用程序清单文件-》app.manifest)

你会发现这个生成的文件是在项目目录下的,而使用ClickOnce自动生成文件则是在(  项目目录\Properties\  )路径下面、不知道有什么区别

将内容设置为如下-就改一句话


<?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 清单选项
            如果要更改 Windows 用户帐户控制级别,请用以下节点之一替换 
            requestedExecutionLevel 节点。

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

            指定 requestedExecutionLevel 节点将会禁用文件和注册表虚拟化。
            如果要利用文件和注册表虚拟化实现向后 
            兼容性,则删除 requestedExecutionLevel 节点。
        -->
   <span style="background-color: rgb(255, 0, 0);">     <requestedExecutionLevel level="requireAdministrator" uiAccess="false" /></span>
      </requestedPrivileges>
    </security>
  </trustInfo>

  <compatibility xmlns="urn:schemas-microsoft-com:compatibility.v1">
    <application>
      <!-- 此应用程序设计使用的所有 Windows 版本的列表。
      Windows 将会自动选择最兼容的环境。-->

      <!-- 如果应用程序设计为使用 Windows Vista,请取消注释以下 supportedOS 节点-->
      <!--<supportedOS Id="{e2011457-1546-43c5-a5fe-008deee3d3f0}"></supportedOS>-->

      <!-- 如果应用程序设计使用 Windows 7,请取消注释以下 supportedOS 节点-->
      <!--<supportedOS Id="{35138b9a-5d96-4fbd-8e2d-a2440225f93a}"/>-->

      <!-- 如果应用程序设计为使用 Windows 8,请取消注释以下 supportedOS 节点-->
      <!--<supportedOS Id="{4a2f28e3-53b9-4441-ba9c-d69d4a4a6e38}"></supportedOS>-->

    </application>
  </compatibility>

  <!-- 启用 Windows 公共控件和对话框的主题(Windows XP 和更高版本) -->
  <!-- <dependency>
    <dependentAssembly>
      <assemblyIdentity
          type="win32"
          name="Microsoft.Windows.Common-Controls"
          version="6.0.0.0"
          processorArchitecture="*"
          publicKeyToken="6595b64144ccf1df"
          language="*"
        />
    </dependentAssembly>
  </dependency>-->

</asmv1:assembly>


重新编译一下EXE后exe自动带上盾牌标志

可以看看这个链接,或许有帮助

http://blog.csdn.net/df398286232/article/details/9790509



最近又发现一个问题。按照上面怎么设置也不行。。。。。。后来发现不是上面的设置不行。

而是上面所有操作都需要一个最基本的前提,就是你得打开电脑的UAC。

打开UAC之后要重启,保留以上的设置进行重新编译,发现exe带有盾牌


由于是最近发现的问题,嫌麻烦就不重写文章了。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值