我正在维护一个旧的应用程序,其中用户配置存储在注册表中。卸载时留下。我现在正在 WiX 中重写安装程序。
如果注册表中没有默认值,安装程序应添加一个默认值,否则 现有的值应该保留。
我正在考虑如何在 WiX 中做到这一点。我想出的解决方案有点麻烦:
<Property Id="MY_PROPERTY">
<RegistrySearch Root="HKLM" Key="SOFTWARE\MyProduct" Name="MyProperty" Type="raw" />
</Property>
<CustomAction Id="ca.SetDefaultValue" Property="MY_PROPERTY" Value="DefaultValue" />
<InstallExecuteSequence>
<Custom After="RegistrySearch" Action="ca.SetDefaultValue">Not MY_PROPERTY</Custom>
</InstallExecuteSequence>
<Component Id="c.Registry">
<RegistryValue Root="HKLM" Key="SOFTWARE\MyProduct" Name="MyProperty" Type="string" Value="[MY_PROPERTY]" />
</Component>
因此,请进行注册表搜索以查找旧值。如果未设置,请使用计划的自定义操作设置为默认值。然后“像往常一样”创建值。
谁能想出一个更顺畅的方法来做到这一点?
请注意,我无法使用像 Installed
这样方便的变量,因为值可能在那里,由以前的现已卸载的版本留下。
最佳答案
从 Wix Remember Property pattern 开始但更进一步。在 AppSearch
运行并且 REMEMBERME
属性获取或未获取值后,请使用 SetProperty
如果 REMEMBERME=""
,则自定义操作分配默认值。
不过,我更进一步了。我有一个概念,我称之为“属性优先”。基本上,它是一个属性应如何获得其值(value)的优先级列表。
从最高到最低:
- 在用户界面期间输入的属性
- 在命令行传入的公共(public)属性
- 在
AppSearch
期间找到的属性 Property
中定义的默认值表
换句话说,在第一次静默安装期间,没有在命令行传递任何属性,则应使用属性表中的默认值。
在第二次静默安装(没有在命令行中传递任何属性)期间,记住的值应优先于默认值。 (如果不同)
在第一次或第二次静默安装期间,在命令行传递的属性应被视为覆盖值,并优先于默认值和记住的值。
在交互式安装期间,会发生上述规则,并且 UI 应显示该值。如果用户更改该值,则这就是最终值。
我将让您自行决定如何实现各种自定义操作来执行此操作。它通常涉及一个临时 Prop 和一个真实 Prop 以及一系列具有正确执行调度和条件的设置属性 CA,以执行您希望它执行的操作。
关于wix - 如果没有的话,在注册表中设置默认值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11382997/