错误"错误LGHT0204:ICE57:组件' XXX'具有每用户数据和密钥路径,可以是每用户或每台机器"是什么意思?
是否可以修复此错误?
在任何情况下,Wix都会创建msi文件,并且可以安装该应用程序。这是真正的错误还是只是警告?如果是警告,我可以忽略此错误吗?或者应该纠正什么?
这是我的单一程序包创作安装的wxs文件:
<?xml version='1.0' encoding='windows-1252'?>
<Wix xmlns='http://schemas.microsoft.com/wix/2006/wi'>
<Product Name='Foobar 1.0' Id='GUID' UpgradeCode='GUID'
Language='1033' Codepage='1252' Version='1.0.0' Manufacturer='Acme Ltd.'>
<Package Id='*' Keywords='Installer' Description="Acme's Foobar 1.0 Installer"
Comments='Foobar is a registered trademark of Acme Ltd.' Manufacturer='Acme Ltd.'
InstallerVersion='100' Languages='1033' Compressed='yes' SummaryCodepage='1252' />
<Property Id="ALLUSERS" Secure="yes" Value="2" />
<Property Id="MSIINSTALLPERUSER" Secure="yes" Value="1" />
<Property Id='ApplicationFolderName' Value="Acme" />
<Property Id='WixAppFolder' Value="WixPerUserFolder" />
<Media Id='1' Cabinet='Sample.cab' EmbedCab='yes' DiskPrompt="CD-ROM #1" />
<Property Id='DiskPrompt' Value="Acme's Foobar 1.0 Installation [1]" />
<Directory Id='TARGETDIR' Name='SourceDir'>
<Directory Id='ProgramFilesFolder' Name='PFiles'>
<Directory Id='Acme' Name='Acme'>
<Directory Id='INSTALLDIR' Name='Foobar 1.0'>
</Directory>
</Directory>
</Directory>
<Directory Id="ProgramMenuFolder" Name="Programs">
<Directory Id="ProgramMenuDir" Name="Foobar 1.0">
<Component Id="ProgramMenuDir" Guid="GUID">
<RemoveFolder Id='ProgramMenuDir' On='uninstall' />
<RegistryValue Root='HKMU' Key='Software\[Manufacturer]\[ProductName]' Type='string' Value='' KeyPath='yes' />
</Component>
</Directory>
</Directory>
</Directory>
<DirectoryRef Id="INSTALLDIR">
<Component Id='MainExecutable' Guid='GUID'>
<File Id='FoobarEXE' Name='FoobarAppl10.exe' DiskId='1' Source='FoobarAppl10.exe' >
<Shortcut Id="startmenuFoobar10" Directory="ProgramMenuDir" Name="Foobar 1.0" WorkingDirectory='INSTALLDIR' Icon="Foobar10.exe" IconIndex="0" />
</File>
<RegistryKey Root="HKMU" Key="Software\[Manufacturer]\[ProductName]">
<RegistryValue Name="FoobarEXE" Value="1" KeyPath="yes" Type="integer" />
</RegistryKey>
</Component>
</DirectoryRef>
<Feature Id='Complete' Title='Foobar 1.0' Description='The complete package.'
Display='expand' Level='1' ConfigurableDirectory='INSTALLDIR'>
<Feature Id='MainProgram' Title='Program' Description='The main executable.' Level='1'>
<ComponentRef Id='MainExecutable' />
<ComponentRef Id='ProgramMenuDir' />
</Feature>
</Feature>
<Icon Id="Foobar10.exe" SourceFile="FoobarAppl10.exe" />
</Product>
</Wix>
答案 0 :(得分:2)
这个问题已被问过几十次了。请不要发布所有链接,请在SO中搜索ICE57并参考说明和解答。例如:
(WiX) Program files shortcut for per-machine install
和此:
How to fix ICE57.Per-User installation
简短回答:如果您始终按用户安装并在每个系统安装时修复它,请忽略它。这是对MSI文件的静态测试,无法知道最终安装的上下文,因此无论如何都会发出警告。
答案 1 :(得分:2)
ICE57检查的目的是验证组件不是每个用户和每个机器文件和/或注册表设置的混合。然而Rob Mensching在http://sourceforge.net/p/wix/mailman/message/26687047/中的评论表明ICE57检查并不完美:
IIRC,这是ICE57中的一个错误。 Windows Installer团队没有看 评估这些价值时的ALLUSERS属性......这是很久以前的事了 虽然如此,我的记忆可能已经衰退了一点。
您的示例在单一程序包创作规则方面看起来是正确的。两个主要目标目录是 ProgramFilesFolder 和 ProgramMenuFolder ,这两个目录都针对每个用户的安装进行了适当的重定向。注册表项根目录是HKMU,在每台计算机上安装时最终为HKLM,在每个用户安装时最终为HKCU。
这看起来像ICE57中的一个错误。遗憾的是,我们无法访问ICE57源,因此很难直接修复。有几种方法可以解决这个问题:
选项1 - 抑制ICE57
不理想,因为它会抑制这一组的所有四个规则,而不仅仅是失败的规则。
选项2 - 使用广告快捷方式
将您的快捷方式更改为广告,并丢失相关的注册表项。 MainExecutable
组件简化为:
<Component Id='MainExecutable' Guid='GUID'>
<File Id='FoobarEXE' Name='FoobarAppl10.exe' DiskId='1'
Source='FoobarAppl10.exe' KeyPath='yes'>
<Shortcut Id="startmenuFoobar10"
Directory="ProgramMenuDir"
Name="Foobar 1.0"
WorkingDirectory='INSTALLDIR'
Icon="Foobar10.exe"
IconIndex="0"
Advertise='yes'/>
</File>
</Component>
通过宣传的捷径,ICE57检查似乎更可靠。
关于ICE检查的注意事项
所有ICE检查都存储在 darice.cub 文件中。这实际上是一个Windows Installer数据库文件,您可以使用 Orca 打开该文件。在典型的WIX安装中,可以在以下位置找到此文件:C:\Program Files (x86)\WiX Toolset vX.Y\bin
。如果您在 Orca 中打开 darice.cub ,您可以将ICE检查视为自定义操作。大多数引用文件中嵌入的一个或多个二进制DLL。一些是作为VBS实现的。