'烧'和使用WiX的自定义MBA - 在NetFx45Web软件包上修复失败

时间:2013-05-01 07:11:33

标签: wix windows-installer bootstrapper burn

我写了一个自定义Managed Bootstrapper Application(MBA)并获得了大部分功能,除了修复。检查捆绑日志提供:

[335C:3440][2013-04-29T13:51:41]w343: Prompt for source of package:
NetFx45Web, payload: NetFx45Web, path:
D:\dev\Setup\redist\dotNetFx45_Full_setup.exe
[335C:3440][2013-04-29T13:51:41]e054: Failed to resolve source for file:
D:\dev\Setup\redist\dotNetFx45_Full_setup.exe, error: 0x80070002.
[335C:3440][2013-04-29T13:51:41]e000: Error 0x80070002: Failed while
prompting for source (original path
'D:\dev\Setup\redist\dotNetFx45_Full_setup.exe').
[335C:3440][2013-04-29T13:51:41]e313: Failed to acquire payload: NetFx45Web
to working path:
C:\Users\admin\AppData\Local\Temp\{ab28ebc1-ce07-49bf-bb1f-bb83a4944aeb}\NetFx45Web,
error: 0x80070002.
[335C:164C][2013-04-29T13:51:41]e000: Error 0x80070002: Failed while
caching, aborting execution.
[335C:164C][2013-04-29T13:51:41]i399: Apply complete, result: 0x80070002,
restart: None, ba requested restart:  No
[335C:164C][2013-04-29T13:51:43]i500: Shutting down, exit code: 0x80070002
[335C:164C][2013-04-29T13:51:43]i410: Variable: ArpSystemComponentCustom = 1
[335C:164C][2013-04-29T13:51:43]i410: Variable: NETFRAMEWORK45 = 378389

有趣的是,即使主日志文件填充了特定于包的日志文件变量名,Burn也不会实际生成该文件。我的猜测是在它能够这样做之前失败了。

我已将NetFx45Web软件包包含在我的WiX软件包中:

<PackageGroupRef Id="NetFx45Web"/>

我的BootstrapperCore.config如下:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <configSections>
        <sectionGroup name="wix.bootstrapper"
                      type="Microsoft.Tools.WindowsInstallerXml.Bootstrapper.BootstrapperSectionGroup,
                      BootstrapperCore">
            <section name="host"
                     type="Microsoft.Tools.WindowsInstallerXml.Bootstrapper.HostSection,
                     BootstrapperCore" />
        </sectionGroup>
    </configSections>

    <startup useLegacyV2RuntimeActivationPolicy="true">
        <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5"/>
    </startup>
    <wix.bootstrapper>
        <host assemblyName="MyCustomMBA">
            <supportedFramework version="v4\Full"/>
            <supportedFramework version="v4\Client"/>
        </host>
    </wix.bootstrapper></configuration>

我查看了相关的邮件列表主题:

我在那里讨论了ResolveSource的问题,涵盖了。

为什么修理失败?安装/卸载工作完全正常。

1 个答案:

答案 0 :(得分:5)

错误0x80070002表示无法找到该文件。日志文件中也没有显示ResolveSource()回调返回Result.Download以指示Burn引擎尝试从Internet重新获取.NET Framework。如果引导程序应用程序(BA)返回Result.Download,您将看到有关从某个URL获取NETFX4.5有效负载的日志条目。