Wix学习整理(3)——关于Windows Installer和MSI

本文详细介绍了Windows Installer的工作原理及其核心组成部分MSI文件。解释了MSI文件如何存储安装信息,并介绍了MSI数据库的重要表,如Feature、Component和Directory等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

关于Windows Installer

Windows Installer是微软Windows操作系统自带的一个软件安装和配置服务,其实现了软件安装的业务逻辑:如何安装软件?如何修改注册表键值?如何创建快捷方式?如何操作网站目录或注册服务?等等。Windows Installer技术由两部分组成:客户端安装程序服务(Msiexec.exe)和Microsoft软件安装包文件(MSI)。

关于MSI

Windows Installer是从一个数据库中来获取软件安装的相关信息。MSI文件就是一个Windows Installer的数据库,它包含了安装一种产品所需信息、安装(或卸载)程序所需的指令和数据;它将程序的组成文件和功能关联起来;它还包含有关安装过程本身的信息,如目标文件夹路径、系统依赖项、安装选项和控制安装过程的属性。

MSI数据库的几个重要表

既然MSI是一个数据库,那么它就应该由多个关系表来组成。下面我们就简单地介绍MSI的几个重要的表。

表格 1 MSI的几个重要表说明

表名

说明

Directory

指定了产品的目录结构,包括源目录结构和目标目录结构。

Component

指定了产品的基本组件结构。

Feature

Component的组合就称为Feature,是用户选择安装的可视部件。

File

指定了需要安装到目标目录的文件。

ShortCut

记录了产品需要在目标计算机上安装快捷方式所需的信息。

Register

记录了产品需要在目标计算机上注册的注册表键值信息。

Property

记录了产品安装过程中所需的属性值。

Feature表和Component表

Feature和Component是软件安装中非常重要的两个概念。Feature和Component都可以翻译为组件,两者的区别可以说是:Feature是逻辑上的而Component是物理上的。Feature是应用或产品所有功能的一个子集,用户可以独立地选择是否安装。Component是产品或应用的最小组成单元,它可以由一个文件,或一个快捷方式,或一个注册表键值,或它们的组合来组成。

Feature是由Component组成的。Feature具有树状嵌套结构,最大深度为16。在安装的过程中,可以由用户来选择是否安装某个Feature。若父Feature没有被选择,则子Feature也不会被安装。

Component是产品或应用的一小片,每一个要安装的Component都要由一个唯一的GUID值来标识,以便Windows Installer进行跟踪。若某个Component没有GUID值,则安装时不会被安装注册,无GUID的Component一般用于只在安装时的功能实现,例如删除某些临时文件等。

Directory表说明

Directory表指定了产品安装的目录结构,包括目标目录结构和源目录结构。Directory表有三个表项:标识符ID、父目录Directory_Parent和DefaultDir。表项Directory_Parent指向该目录的父目录,而通过表项ID和DefaultDir的值来确定目标目录结构和源目录结构。

目录结构必须有且仅有一个根目录,这个根目录的标识符必须指定为TARGETDIR(TARGETDIR是Windows Installer预定义的属性,其值可以通过命令行或用户界面进行设置),而根目录的SourceDir则必须指定为SourceDir(SourceDir默认的属性值为.msi文件所在的路径)。如果属性TARGETDIR的值被指定了,则目标根目录为TARGETDIR的属性值;若该属性未有值,则目标根目录为Windows Installer预定义属性ROOTDRIVE的值。而源根目录则为SourceDir的属性值。

对于非根目录,若Directory的标识符ID中指定的属性被定义了,则该属性的值即为目标目录,否则取DefaultDir表项中的值作为目标父目录下的一个子目录。而源目录则是将DefaultDir表项中指定的值作为源父目录的一个子目录。

五个必需属性

每个安装包必须要有五个必需属性(Required Properties):ProductCode、ProductLanguage、Manufacturer、ProductName和ProductVersion。

表格 2 五个必需属性

属性名

说明

ProductCode

唯一的、大写的GUID值,用于标识要安装的产品。

ProductLanguage

指示了用户界面上除写入数据库的字符串外的其余字符串所用的语言的数字ID(如1033、2046)。

Manufacturer

指示产品生产厂商的字符串值。

ProductName

产品名称。

ProductVersion

产品版本号,版本号的格式为major.minor.build,其中major和minor最大数字为255,build的最大数字为65535。

Windows Installer通过MSI(Microsoft Installer)包提供了应用程序的安装、维护卸载,是管理复杂软件安装过程的强大工具。在创建MSI安装包时,配置组件属性以及设置条件性安装是两个关键的步骤,它们直接影响到软件的安装流程用户体验。为了深入了解这两个方面,建议阅读《Windows Installer实用指南:英文详解全面操作》,这本书将为您提供从基础到高级配置的全面指南。 参考资源链接:[Windows Installer实用指南:英文详解全面操作](https://wenku.youkuaiyun.com/doc/87o5pzn4k2?spm=1055.2569.3001.10343) 在创建MSI安装包时,配置组件属性是确保应用程序能够在目标系统上正确安装运行的重要环节。组件是安装包中的基本部署单元,可以包含文件、快捷方式、注册表项等。配置组件属性通常涉及到设置组件的可见性、权限、安装位置等。例如,如果希望组件只在特定的系统环境中安装,就可以设置相应的条件属性。 条件性安装则允许安装程序根据特定条件自动决定是否安装某些组件。这些条件可能基于系统的当前状态,如操作系统版本、存在的软件、系统环境变量等。例如,可以设置条件确保某个组件只在Windows 10系统上安装,或者只在安装了特定版本的.NET Framework之后安装。 要实现条件性安装,您需要熟悉MSI数据库中的条件表达式。在安装包的编辑工具中,如Orca或Visual Studio中的安装项目,您可以为每个组件配置条件表达式。编写正确的条件表达式需要一定的实践经验,因此,通过阅读《Windows Installer实用指南:英文详解全面操作》来学习实用的示例最佳实践是非常有价值的。 此外,书中可能还包括如何使用Windows Installer的脚本语言——安装脚本语言(InstallScript)或Windows Installer XML(WiX)工具集——来创建自定义安装行为。这些知识对实现复杂安装逻辑至关重要。 在深入实践之前,建议首先通过《Windows Installer实用指南:英文详解全面操作》了解MSI的基础知识,然后参考书中提供的实战案例来加深理解。这样,您不仅能掌握如何创建MSI安装包,还能在遇到复杂安装问题时,具备查找应用正确解决方案的能力。 参考资源链接:[Windows Installer实用指南:英文详解全面操作](https://wenku.youkuaiyun.com/doc/87o5pzn4k2?spm=1055.2569.3001.10343)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值