WIX: 用XmlConfig修改ApplicationHost.config出错

错误描述

我们的网站通过WIX生成的MSI安装到IIS上。为了在ApplicationHost.config中加入我们网站专用的Advanced Logging的配置信息,我们用了XmlConfig来修改ApplicationHost.config。结果MSI安装报错:需要修改的XML节点也就是不存在。

分析 

我们在调研中发现,WIX使用了一个deferred CA(Custom Action)- ConfigureIIs在IIS中创建和配置网站。WIX使用了另外一个CA - SchedXmlConfig来处理XmlConfig。SchedXmlConfig是Immediate的,它会在安装过程中动态地安排另外两个deferred CA - ExecXmlConfigRollback和ExecXmlConfig在合适的时机执行,这两个CA就是真正修改XML文件的。但是,在默认的InstallExecuteSequence中,SchedXmlConfig总是在ConfigureIIs之前执行,并且会把ExecXmlConfigRollback和ExecXmlConfig安排在ConfigureIIs之前执行。所以,当WIX去修改ApplicationHost.config时,我们的网站还没有创建出来呢,自然就会报错了。

解决方法   

我们注意到SchedXmlConfig总是会把ExecXmlConfigRollback和ExecXmlConfig安排在它自己之后运行,因此,解决的方法就是把SchedXmlConfig放到ConfigureIIs之后执行。

我们可以用Orca.exe来直接修改编译生成的MSI文件。但更好的办法是用标记在我们的WIX代码文件中修改SchedXmlConfig的执行时机:

 
    

当然了,这个办法可以用来修改任意一个WIX预定义CA的默认执行时机。 

你可能感兴趣的:(Deployment)