6

ExcelファイルからAccessデータベースにデータをインポートするデータベースアプリを作成しました。

アプリを実行したり、データベースにレコードを挿入したりするのに問題があったことはありませんが、ExcelからAccessにデータをインポートする関数を実行するとすぐに、次の警告が表示されます。

要求された操作には昇格が必要です-ダイコードによる:

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

これを引き起こしているものとそれを回避する方法はありますか

4

1 に答える 1

8

delphiCreateOleObject関数は、昇格を必要とするCoCreateInstanceWinApiメソッドを内部的に呼び出します。これに対処するためのいくつかのオプションがあります。

1)要求された実行レベル 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エントリを参照してください。

于 2012-05-06T22:10:44.647 に答える