1

これは私の.wxsファイルです

特に、LocalSystem ユーザーとしてサービスをインストールし、開始しました。

        <!-- Directory where [prey]/versions/[version] will be -->
    <Directory Id="ProgramFilesFolder">
      <Directory Id="INSTALLLOCATION" Name="Prey">
        <Directory Id="VersionsDir" Name="versions">
          <Directory Id="VersionDir" Name="$(var.ProductVersion)">
            <Directory Id="BinDir" Name="bin">
              <Directory Id="BinWindowsDir" Name="windows">
                <Component Id="CronServiceExe"
                           Guid="ECC25B2A-FB2E-425A-92AD-DCF1D34204FF">
                  <File Id="file_8FF048AD40124B9F9C07126F2C14A765"
                        Checksum="yes"
                        KeyPath="yes"
                        Source="source-msi\versions\0.10.0\bin\windows\cronsvc.exe" />
                  <ServiceInstall Id="CronServiceInstaller"
                                  Type="ownProcess"
                                  Vital="yes"
                                  Name="CronService"
                                  DisplayName="Cron Service"
                                  Start="auto"
                                  Account="LocalSystem"
                                  ErrorControl="normal"
                                  Interactive="no">
                  </ServiceInstall>
                  <ServiceControl Id="StartService"
                                  Start="install"
                                  Stop="both"
                                  Remove="uninstall"
                                  Name="CronService"
                                  Wait="yes" />
                </Component>
                <Component Id="CronServiceDll"
                           Guid="75C4129B-C28A-45A8-9F06-CB496259FE7F">
                  <File Id="file_11D016207EA34826A20A52524A3A82BC"
                        Checksum="yes"
                        KeyPath="yes"
                        Source="source-msi\versions\0.10.0\bin\windows\Cronsvclib.dll" />
                </Component>
              </Directory>
            </Directory>
          </Directory>
        </Directory>
      </Directory>
    </Directory>

そして、それはうまくいきます。製品をアンインストールする場合を除いて、すべて問題ありません。UACダイアログで尋ねられたにもかかわらず(スクリーンショット)、インストーラーはサービスを停止する権限がないと主張しているためです。

エラーのスクリーンショットは次のとおりです。

Service 'Cron Service' (CronService) could not be stopped. Verify that you have sufficient privileges to stop system services.

そして、ここに特定のログがあります(/L*v詳細ログを取得するオプションを使用してアンインストールしています)。この gistで完全なファイルを取得できます。

2220 ~ 2226 行

MSI (s) (90:80) [19:11:54:953]: Note: 1: 2205 2:  3: Icon 
MSI (s) (90:80) [19:11:54:953]: Note: 1: 2205 2:  3: TypeLib 
MSI (s) (90:80) [19:11:54:953]: Note: 1: 2727 2:  
MSI (s) (90:80) [19:11:54:973]: RESTART MANAGER: Detected that the service CronService will be stopped due to a service control action authored in the package before the files are updated. So, we will not attempt to stop this service using Restart Manager
MSI (s) (90:80) [19:11:54:973]: Note: 1: 2727 2:  
MSI (s) (90:80) [19:11:54:973]: Doing action: InstallInitialize
MSI (s) (90:80) [19:11:54:973]: Note: 1: 2205 2:  3: ActionText 
Action ended 19:11:54: InstallValidate. Return value 1.

4624 ~ 4635 行

MSI (s) (90:80) [19:11:57:196]: Executing op: ActionStart(Name=StopServices,Description=Stopping services,Template=Service: [1])
MSI (s) (90:80) [19:11:57:196]: Executing op: ProgressTotal(Total=1,Type=1,ByteEquivalent=1300000)
MSI (s) (90:80) [19:11:57:196]: Executing op: ServiceControl(,Name=CronService,Action=2,Wait=1,)
MSI (s) (90:80) [19:12:27:239]: Note: 1: 2205 2:  3: Error 
MSI (s) (90:80) [19:12:27:239]: Note: 1: 2228 2:  3: Error 4: SELECT `Message` FROM `Error` WHERE `Error` = 1921 
MSI (s) (90:80) [19:16:38:940]: Note: 1: 2205 2:  3: Error 
MSI (s) (90:80) [19:16:38:940]: Note: 1: 2228 2:  3: Error 4: SELECT `Message` FROM `Error` WHERE `Error` = 1709 
MSI (s) (90:80) [19:16:38:940]: Product: Prey Anti-theft -- Error 1921. Service 'Cron Service' (CronService) could not be stopped.  Verify that you have sufficient privileges to stop system services.
MSI (s) (90:80) [19:17:08:983]: Note: 1: 2205 2:  3: Error 
MSI (s) (90:80) [19:17:08:983]: Note: 1: 2228 2:  3: Error 4: SELECT `Message` FROM `Error` WHERE `Error` = 1921 
MSI (c) (48:84) [19:12:27:239]: Font created.  Charset: Req=0, Ret=0, Font: Req=MS Shell Dlg, Ret=MS Shell Dlg

そのすべての情報を考えると。管理者としてMSIを開始するには、どこかで管理する必要があると思います。か否か?

それが私の問題です:

  1. .msi インストーラーを「管理者専用」としてセットアップする方法はありますか? (その選択肢が存在する場合)。

  2. 奇妙なことに、私が取得しているすべての投稿と Google の結果は、サービスを停止するのではなく、インストールと開始の問題に関するものです。だから私は行き止まりです。

どうぞ、すべての助けが非常に役に立ち、感謝されます。

4

1 に答える 1

3

エラー メッセージには、アクセス許可の問題であるという提案が含まれています。サービスをインストールするには、最初に昇格されたアクセス許可が必要になるため、これはめったにありません。通常、サービスの停止に失敗するのは、サービスが停止要求に十分迅速に応答しないのと同じくらい単純です。CronService は停止要求に応答するサービス インターフェイスを実装していますか? MSI も Windows も、サービス プロセスを強制終了して停止することはありません。

于 2013-07-06T00:06:46.973 に答える