由于工作需要,学习了一段时间Wix,总算小有起色。鉴于国内Wix  的普及和使用有限,这里将个人遇到得问题和解决方案记录下来,以便交流和相互促进。

    

   Wix :全称 Windows Installer XML , 属于微软的一个开源项目,目标是使用 XML 语言灵活的定制具有各种功能的安装包,需要微软的 Windows Installer 服务支 持。

   Wix 生 成的产品为 msi 文 件,这种可执行文件与 exe 文件最大的不同为,它更底层,安装文件的同时可以对系统或者其他软件进行设置。

  下面的所有内容是基于 Wix3.0 版本。

 

 

    Wix 基本入门资料:

    Wix Document

    Wix tutorial ( 仅支持到 Wix2.0)

    这两份资料都可以通过 Wix 的发布网站获取。

 

 

 

1)         Language Codepage 的设置

Language 指所在地区使用的语言,为数字编号。 Codepage 指所在地区的代码页,用来进行 区域区分。 下来列举几个常见的区域代号: 语言                                语言 - 国家      Language       Codepage English                            en-us             1033                1252 Simplified Chinese             zh-cn              2052               936 Traditional Chinese            zh-tw              1028                 950

2)         GUID 的生成

在 VS2005 中,通过 “ 工具 ”——“ 创建 GUID” 生成。 GUID 也可以自行定义,但是前提是要保证唯一。

3)         安装文件描述 XML 自动生成

当安装文件特别多的时候,我们 就需要用专用的工具进行文件描述 XML 的自动生成了,采用的是 Wix 自带的 heat 工具,位于安装目录的 bin 下。     Heat 的使用方法为:     heat.exe [-?] harvestType < harvester arguments> -out sourceFile.wxs     详细见 Wix 说明文档。     例子:     heat.exe  dir ABC -gg -ke -sfrag  -template:fragment -dr INSTALLLOCATION -cg BasicComponentGroup -srd  -out  ABC.wxs     作用为:将目录 ABC (相对目录)下的所有文件(包括空目 录)作为一个 ComponentGroup 添加到 ABC.wxs 文件中,其中根目录为 INSTALLLOCATION ,段标签为 fragment , 运行这行命令会自动生成一个 wxs 文件,里面包含 ABC 目录下所有文件的描述。

4)         Feature 的选择安装

Wix 安装包中所有的组件都是以 Feature 的方式安装到系统中的, Level 是安装级别,是最重要的属性之一,不可缺少。     Level 的值为整型,最小为 0 ,最大 1000 。为 0 的时候此 Feature 不安装。  一般来 说 Level 与选 择安装关联,与之相对应的一个属性为 INSTALLLEVEL ,默认为 1. 小于 1 的 Feature 将不会被安装。 Level 值为 3 的 Feature 为 Typical 类型, Level 值大于 3 为 Complete 类型。 Level 也可以在安装时动态修改,使用 <Condition> 条件判断。例如: <Feature  Id="DesktopFt" Title="Desktop" Level="1">         <Condition  Level="0"><![CDATA[HASDESKTOP <> "1"]]></Condition>         <ComponentRef Id="DesktopShortcutComponent"/>   </Feature>     如果 HASDESKTOP 属性值不为 1 ,那么此 Feature 的 Level 将为 0 ,不会被安装。使用此种方式选择安装需注意 HASDESKTOP 属性的初始化位置,一定要保证在 Feature 初始化前进行。否则设置无效。     也可以采用另一种方法选择性安 装:     HASDESKTOP 属性修改的地方添加 <Publish> 。       <Publish Event="AddLocal"  Value="ALL">1</Publish>       <Publish Event="Remove"  Value="DesktopFt"><![CDATA[HASDESKTOP <>  "1"]]></Publish>     这样效果一样,但是不需要 HASDESKTOP 的值的初始化在 Feature 之前。     ( 附注:    注意此种方式下内置属性 REMOVE 的值就不再为空,那么在安装时也不能以 REMOVE 来判断当前操作 )

5)         Property 的使用

Wix 中使用自定义变量的方法为声明 Property (属性)。 Property 分为两种:全局的和局部的。全 局属性必须全部大写,否则视为局部属性。 例如: <Property  Id="HASDESKTOP" Value="1"/> 如果改为小写,那么其他文件(也许是 fragment )的代码调用属性无效。 搜索、判断得到的属性一律为全局 属性,大写。例如: <Property Id="VC71PATH">        <RegistrySearch Id="VC71" Type="raw" Root="HKLM"  Key="SOFTWARE\Microsoft\VisualStudio\7.1" Name="InstallDir"/> < /Property> 上述例子为在注册表中查找 VC71 的 InstallDir 的值,如存在将值付给 VC71PATH ,不存在则 VC71PATH 为空。

6)         安装包的中文化

Wix 默认的语言为 en-us ,中文化需要另外添加 zh-cn 或 zh-tw 的描述文件。 拥有了中文拓展的文件以后,在代码中使用 loc 调用属性即可,使用方式与 en-us 无异。 当然也可以自定义一些中文化的标签,格式为: <WixLocalization Culture="zh-cn"  xmlns="http://schemas.microsoft.com/wix/2006/localization"> < String Id="LicenseThirdPartText" Overridable="yes"> 请仔细阅读以下声明 </String> < /WixLocalization> 调用方式为: text  =”!(loc.LicenseThirdPartText)”

7)         内置 CustomAction 的使用

1. Quiet Execution Custom  Action 安静模式下执行操作。允许用户在后台执行一些命令,但是不 出现执行窗口。     例 1 ,安静模式下执行 CMD 操作  <Property Id="QtExecCmdLine" Value="command line to run"/> < CustomAction Id="QtExecExample" BinaryKey="WixCA" DllEntry="CAQuietExec"  Execute="immediate" Return="check"/> < InstallExecuteSequence>       <Custom Action="QtExecExample"  After="TheActionYouWantItAfter"/> < /InstallExecuteSequence> 采用安静模式执行 CMD 操作,但是不出现 CMD 命令窗口。注意 Value 中的命令以及应用程序必须加引 号,即使没有空格也要加上。

例 2 ,安静模式下执行其他应用程序操作 <CustomAction I d="QtExecDeferredExampleWithProperty_Cmd"  Property="QtExecDeferredExampleWithProperty"                Value=""[#MyExecutable.exe]"" Execute="immediate"/> < CustomAction Id="QtExecDeferredExampleWithProperty" BinaryKey="WixCA"  DllEntry="CAQuietExec"               Execute="deferred"  Return="check" Impersonate="no"/>

< InstallExecuteSequence>     <Custom Action="QtExecDeferredExampleWithProperty_Cmd"  After="CostFinalize"/>     <Custom  Action="QtExecDeferredExampleWithProperty"  After="TheActionYouWantItAfter"/> < /InstallExecuteSequence>

2.ShellExecute CustomAction 执行打开文档或 URL 等操作。典型应用为安装完成后打开帮助 文件或则运行安装程序。 例: <Property Id="WixShellExecTarget" Value="myapplication.exe"  />     <CustomAction Id="LaunchApplication"          BinaryKey="WixCA"         DllEntry="WixShellExec"          Impersonate="yes" />     </Product>