使用Wix的技巧和提示有哪些?

  • 回答 (10)
  • 关注 (0)
  • 查看 (339)

我想知道在以下方面使用Wix的有效建议:

  • 设置Wix项目(布局、引用、文件模式)
  • 将Wix集成到解决方案中,并构建/发布过程
  • 为新安装和升级配置安装程序
  • 以及你想要分享的关于Wix的优点
liqoeiliqoei提问于
少女女先疯队长大学生 码字爱好者 工商管理专业回答于

使用相同的源文件创建 Live, Test, Training等版本。

为每个安装程序创建唯一的UpgradeCode,并自动为每个安装程序定义每个Guid的第一个字符,留下剩下的31个惟一字符。

前提条件

假设

  • Wix变量用于定义UpgradeCode、ProductName、InstallName。
  • 安装程序正常工作
  • 所有组件都保存在一个文件中(Components.wxs)。如果你有多个文件,这个过程将会起作用,并且会有更多的工作要做。

目录结构

  • Setup.Library
    • 所有wxs文件(组件、特性、UI对话框)
    • Common.Config.wxi(ProductCode=“*“,ProductVersion,PlatformProgramFilesFold,...)
  • Setup.Live (wixproj)
    • 使用“添加现有文件” - >“添加为链接”(Visual Studio中添加按钮旁边的向下箭头按钮)链接所有Setup.Library文件
    • Config.wxi(有唯一的UpgradeCode,ProductName,InstallName,...)
  • Setup.Test
    • Config.wxi是为Test环境配置的。

过程

  • 创建.Setup.Library目录,并将所有wxs和wxi文件(Config.wxi除外)从现有项目中移出。
  • 按照正常的wixproj.测试环境创建Setup.Live, Setup.Test等程序
  • 在安装过程中,在wixproj中添加BeforeBuild目标,.Live来执行MSBuild社区任务,FileUpdate来修改Guids(我使用了Live, B用于测试,C用于练习)
  • 添加AfterBuild目标,将Components.wxsGuids还原回0。
  • 使用Orca验证每个MSI中的每个组件都有修改的GUID。
  • 验证原始GUID是否已恢复。
  • 确认每个MSI安装(并升级)正确的产品和位置。

Config.Common.wxi

<?xml version="1.0" encoding="utf-8"?>
<Include>
<!-- Upgrade code should not change unless you want to install 
     a new product and have the old product remain installed, 
     that is, both products existing as separate instances. -->
<?define UpgradeCode = "YOUR-GUID-HERE" ?>

<!-- Platform specific variables -->
<?if $(var.Platform) = x64 ?>
  <!-- Product name as you want it to appear in Add/Remove Programs-->
  <?define ProductName = "Foo 64 Bit [Live]" ?>
<?else ?>
  <?define ProductName =  "Foo [Live]" ?>
<?endif ?>

<!-- Directory name used as default installation location -->
<?define InstallName = "Foo [Live]" ?>

<!-- Registry key name used to store installation location -->
<?define InstallNameKey = "FooLive" ?>

<?define VDirName = "FooLive" ?>
<?define AppPoolName = "FooLiveAppPool" ?>
<?define DbName = "BlahBlahLive" ?>
</Include>

Config.Common.wxi

<?xml version="1.0" encoding="utf-8"?>
<Include>
<!-- Auto-generate ProductCode for each build, release and upgrade -->
<?define ProductCode = "*" ?>

<!-- Note that 4th version (Revision) is ignored by Windows Installer -->
<?define ProductVersion = "1.0.0.0" ?>

<!-- Minimum version supported if product already installed and this is an upgrade -->
<!-- Note that 4th version (Revision) is ignored by Windows Installer -->
<?define MinimumUpgradeVersion = "0.0.0.0" ?>

<!-- Platform specific variables -->
<?if $(var.Platform) = x64 ?>
   <?define Win64 = "yes" ?>
   <?define PlatformProgramFilesFolder = "ProgramFiles64Folder" ?>
<?else ?>
   <?define Win64 = "no" ?>
   <?define PlatformProgramFilesFolder = "ProgramFilesFolder" ?>
<?endif ?>

<?define ProductManufacturer = "Foo Technologies"?>

<!-- Decimal Language ID (LCID) for the Product. Used for localization. -->
<?define ProductLanguage = "1033" ?>

<?define WebSiteName = "DefaultWebSite" ?>
<?define WebSitePort = "80" ?>

<?define DbServer = "(local)" ?>
</Include>

Components.wxs

<?xml version="1.0" encoding="utf-8"?>
<Wix xmlns="http://schemas.microsoft.com/wix/2006/wi">
  <!-- The pre-processor variable which allows the magic to happen :) -->
  <?include $(sys.CURRENTDIR)\Config.wxi?>
  <?include ..\Setup.Library\Config.Common.wxi?>
  <Fragment Id="ComponentsFragment">
    <Directory Id="TARGETDIR" Name="SourceDir">
      <Directory Id="$(var.PlatformProgramFilesFolder)">
        <Directory Id="INSTALLLOCATION" Name="$(var.InstallName)">
          <Component Id="ProductComponent" Guid="0XXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX" KeyPath="yes">
          ...

注意:我现在建议将Guid属性排除在组件之外(相当于*),每个组件使用一个文件,并将文件设置为keypath。这消除了调用ModifyComponentsGuids和RevertComponentsGuids目标的需要。但是,对于所有的组件,这应该是不可能的。

Setup.Live.wixproj

<Import Project="$(MSBuildExtensionsPath)\MSBuildCommunityTasks\MSBuild.Community.Tasks.Targets" />
<Target Name="BeforeBuild">
  <CallTarget Targets="ModifyComponentsGuids" />
</Target>
<Target Name="AfterBuild">
  <CallTarget Targets="RevertComponentsGuids" />
</Target>
<!-- Modify the first character of every Guid to create unique value for Live, Test and Training builds -->
<Target Name="ModifyComponentsGuids">
  <FileUpdate Files="..\Setup.Library\Components.wxs" Regex="Guid=&quot;([a-f]|[A-F]|\d)" ReplacementText="Guid=&quot;A" />
</Target>
<!-- Revert the first character of every Guid back to initial value -->
<Target Name="RevertComponentsGuids">
  <FileUpdate Files="..\Setup.Library\Components.wxs" Regex="Guid=&quot;([a-f]|[A-F]|\d)" ReplacementText="Guid=&quot;0" />
</Target>

最后

  • 这个过程还应该为不同的合并模块创建不同的安装程序(Live, Test作为特性)对于相同的安装程序。我使用了不同的安装程序,因为它会更安全,如果他们在同一个盒子上,而你只是使用不同的合并模块的特性,那么可能会有人升级Live。
  • 如果你使用MSI来执行升级和新安装程序,即主要升级方法,并且将安装位置保存在注册表中,请记住为每个安装创建一个变量名。
  • 我们还在每个Config.wxi中创建变量,为每个安装程序启用唯一的虚拟目录名称、应用程序池、数据库名称等等。

更新1:如果你为每个文件创建带有Guid="*"的组件,则自动生成组件Guids将消除调用FileUpdate任务的需要,将文件设置为keypath。

更新2:我们遇到的问题之一是,如果您不自动生成组件Guid而构建失败,那么需要手动删除临时文件。

更新3:找到了一种消除对SVN依赖的方法:外部和临时文件创建。这使得构建过程更有弹性(如果不能通配你的Guids,则是最好的选择)。

更新4:在Wix 3.0+中,支持更多使用实例

回答过的其他问题

除了比特币,区块链还可以应用到哪些技术场景?以及哪些公司在搞区块链?

少女女先疯队长大学生 码字爱好者 工商管理专业
首先不要把区块链想的过于高深,他是一个分布在全球各地、能够协同运转的数据库存储系统。 与传统数据库运作的区别在于,读写权限掌握在一个公司或者一个集权手上,然而区块链认为,任何有能力架设服务器的人都可以参与其中。 区块链于比特币的关系在于:区块链是一项技术,加密货币是其开发实现的一...... 展开详请

如何利用云计算加固服务器,防止SSH攻击?

少女女先疯队长大学生 码字爱好者 工商管理专业
PyFilter可以起到保护作用, 可以将其配置为作为系统服务运行,以便每次重启服务器时它都会启动。 在PyFilter目录中,使用脚本install.sh为PyFilter创建服务并使其在系统启动时运行。 修改脚本的执行权限: sudo chmod +x install.sh...... 展开详请

云计算实现中虚拟化技术是如何运用的?

少女女先疯队长大学生 码字爱好者 工商管理专业
云计算模式以虚拟化技术为基础,特别是IAAS层。 云计算是一个运维,SLA,计费等方面的综合工程。有些必须要虚拟化提供的功能,数据信息进行。作为云计算的基础技术,一台一台的服务器需要先进行虚拟化才能合理使用服务器硬件资源。 比如7*24小时不停机,需要通过虚拟化提供的功能;虚拟机...... 展开详请

在腾讯云进行备案域名是否支持微信访问?

少女女先疯队长大学生 码字爱好者 工商管理专业

拦截的话说明域名被举报的太多了去申诉一下吧

申请到一个签名以后,这个签名在有效期内可以给多个客户端同时使用么?

少女女先疯队长大学生 码字爱好者 工商管理专业

TGit里怎么设置SSH密钥和HTTPS用户名密码?

少女女先疯队长大学生 码字爱好者 工商管理专业

这个里面可以设置

https://git.cloud.tencent.com/profile/keys

关于作者

少女女先疯队长

大学生 码字爱好者 工商管理专业

所属标签

扫码关注云+社区