我有一个msi(用WIX编写),它有一个绑定到自定义属性的复选框(称之为MY_PROPERTY).我想从命令行运行这个msi,为此属性指定0(未选中)或1(已选中).我的脚本将确定适当的值(基于环境)并将该值注入msiexec命令行.我的命令行看起来像这样:
msiexec /i my_installer.msi MY_PROPERTY=$value
其中$value为1或0,具体取决于环境.问题是无论我在命令行为MY_PROPERTY提供什么值,都会选中复选框(并且该属性将始终设置为1).取消选中复选框的唯一方法是不指定属性(保持未定义).应该注意,无论UI是否显示,都会出现这种情况(在上面的命令行中添加“/ quiet”不会改变这种行为).
This msdn post似乎表明这是Windows安装程序中已知的“错误”(或者更确切地说,无论创作系统编写的是msi).建议将构建后的msi hack作为解决方案.我想知道是否有人遇到过这个问题并提出了更好的解决方法/解决方案.谢谢!
更新
我看到这个问题的三个解决方案:
>从@Damien开始,让包装脚本在其值为0时不将属性传递给msiexec.这会使脚本更复杂,并且可能会阻止我覆盖默认为“已检查”的复选框的值.
>从@Michael Urman添加一个自定义操作,如果其值为零,则清除该属性.这使得msi更复杂,我将不得不为UI中的每个复选框添加这样的自定义操作.
>另一个想法是简单地禁止在我们的msi安装程序中使用复选框,并使用单选框或下拉菜单代替“真/假”问题.虽然这限制了我们的安装程序的UI选项,但它允许包装器脚本保持简单,并且不需要自定义操作来“破解”属性.
我目前倾向于选项3,虽然选项1可能是我原始问题的最佳答案.有什么想法吗?