加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

如何用Delphi授予高程

发布时间:2020-12-15 04:07:42 所属栏目:大数据 来源:网络整理
导读:我编写了一个数据库应用程序,可以将excel文件中的数据导入Access数据库. 我从来没有遇到过运行应用程序,将记录插入数据库的麻烦,但是只要我运行将数据从Excel导入Access的功能,我就会收到以下警告: 请求的操作需要提升 – 通过芯片代码: LAccess := Create
我编写了一个数据库应用程序,可以将excel文件中的数据导入Access数据库.

我从来没有遇到过运行应用程序,将记录插入数据库的麻烦,但是只要我运行将数据从Excel导入Access的功能,我就会收到以下警告:

请求的操作需要提升 – 通过芯片代码:

LAccess := CreateOleObject('Access.Application');

造成这种情况的原因是什么,有办法绕过它

解决方法

CreateOleObject delphi函数在内部调用需要提升的 CoCreateInstance WinApi方法.你有几个选择来处理这个问题.

1)向您的应用添加清单,包括requested execution level requireAdministrator.

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0">
<assemblyIdentity
    name="Your app name goes here"
    processorArchitecture="x86"
    version="5.1.0.0"
    type="win32"/>
<description>your app description goes here</description>
<dependency>
    <dependentAssembly>
        <assemblyIdentity
           type="win32"
           name="Microsoft.Windows.Common-Controls"
           version="6.0.0.0"
           processorArchitecture="x86"
           publicKeyToken="6595b64144ccf1df"
           language="*"
        />
     </dependentAssembly>
  </dependency>
   <trustInfo xmlns="urn:schemas-microsoft-com:asm.v2">
      <security>
      <requestedPrivileges>
        <requestedExecutionLevel
          level="requireAdministrator"
          uiAccess="false"/>
      </requestedPrivileges>
    </security>
   </trustInfo>
</assembly>

2)您可以启动升级的辅助进程来执行任务或创建运行提升的COM对象,您可以在这些MSDN条目中找到更多信息

> Redesign for UAC Compatibility
> The COM Elevation Moniker

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读