彩票走势图

打包软件InstallShield提示和技巧:设计更新友好的MSI安装

翻译|使用教程|编辑:况鱼杰|2019-12-23 15:00:24.687|阅读 730 次

概述:MSI原始安装项目的第一个发行版的设计可能会对以后应用到该更新的更新的成功产生重大影响。本文提示用于组织您的初始MSI安装项目,并在适当情况下描述了激发这些提示的适用Windows Installer行为或最佳实践准则。

# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>

相关链接:

InstallShield是构建Windows安装程序和MSIX包并直接在Microsoft Visual Studio中创建安装的最快速最简单的方法。借助InstallShield,您可以快速适应行业的变化,更快地进入市场并提供引人入胜的客户体验。      

点击下载InstallShield最新试用版


    MSI原始安装项目的第一个发行版的设计可能会对以后应用到该更新的更新的成功产生重大影响。以下提示用于组织您的初始MSI安装项目,并在适当情况下描述了激发这些提示的适用Windows Installer行为或最佳实践准则。 

注意:这些技巧主要适用于次要升级。通常,主要升级的先卸载后再安装性质使它们较不容易受到与安装项目的组织有关的问题的影响。

提示1、尽可能使用版本密钥文件

    Windows Installer对系统稳定性的部分贡献是严格的文件版本转换规则。但是,在决定是在重新安装还是在更新安装过程中安装组件时,MSI通常仅对组件的密钥文件执行版本比较。确保组件将在您的新产品版本中更新的一种简单方法——为您的密钥文件提供比目标系统上相应文件更高的版本。

 ;   此技巧与MSI最佳实践规则有关,该规则是将最多一个可移植的可执行文件(EXE,DLL,OCX等)放入组件中,并将该文件标记为其组件的密钥文件。除了为您的安装提供最有效的修复模式外,如果在新产品版本中仅更新了一些文件,则拥有更多组件会导致更理想的默认行为。

提示2、将您的产品划分为离散的功能集

 ;   功能的主要用途是为用户提供产品功能的可选部分。 安装程序设计的早期部分是定义希望用户能够看到和配置的功能(和子功能等)。

    大多数安装程序提供自定义安装类型,该安装类型会向用户显示类似于以下内容的面板,用户可以在其中选择要安装的产品功能。

截图未命名.jpg

    安装程序的此最终用户视图是您需要配置的其他功能的基础。

    没有将应用程序划分为功能的固定规则列表。在某些情况下,应用程序的体系结构将建议划分功能(程序文件,帮助文件,工具,示例等)。在其他情况下,有必要在应用程序中定义人为边界,以创建可管理大小的功能。

    将产品划分为用户可选择的功能后,可以将这些功能进一步划分为子功能。对于这些子功能中的每一个,可以将显示属性设置为不可见,将远程安装属性设置为收藏夹父级,并将必需属性设置为是。在这种情况下,用户将仅看到可见的功能并与之交互,但是安装的行为就像子功能中的所有应用程序资源都是主要功能的一部分一样。 

注意:将子功能标记为仅在安装了其父功能时才安装该子功能。

    项目具有的功能越多,重新安装行为的灵活性就越大。REINSTALL属性应在次要升级安装期间设置,它接受要重新安装的功能的列表。在进行次要升级(尤其是作为补丁程序)时,不应使用设置REINSTALL = ALL,而应明确指定要重新安装的功能。

    上图是一个相关的常见实践,即创建顶级的产品功能。

提示3、将用户可配置的注册表数据置于其自身的功能中

    应用较小的升级时,还将重新安装所有正在重新安装的功能中的所有注册表数据。即使没有更新包含注册表数据的组件,也会发生这种情况。

    这意味着任何已从其原始值修改的注册表设置都将恢复为其默认值。在某些情况下,这是可以接受的行为,但是通常您不希望将用户的配置设置替换为原始出厂设置。

    如果您将用户可配置的注册表数据放置在它自己的功能中(如上一个技巧所述),则除非在更新过程中设置的REINSTALL属性的值中列出了该功能,否则不会重新安装该功能。

    如果不想重新安装任何注册表数据,还可以从REINSTALLMODE值中省略m和u标志。但是,此设置适用于整个安装,并且在应用修补程序期间可能会产生不良影响。

提示4、初始安装期间不会自动保存MSI属性值

    除少数例外,在维护模式或更新方案期间,初始安装期间设置的MSI属性值将不可用。如果您认为需要一个属性值供以后的维护或更新安装使用,一种常见的做法是在初始安装过程中将该属性的值写入注册表,并在以后的安装过程中读回数据。

    要将属性的值写入注册表,您可以利用以下事实:注册表的值字段使用已格式化的MSI数据类型。使用Formatted数据类型的MSI数据库字段将在运行时将[PropertyName]形式的表达式扩展为指定属性的值。例如,要将运行安装的用户的帐户名写入注册表,可以创建一个带有数据[LogonUser]的值。

    要在以后的安装过程中回读注册表数据,可以填充AppSearch和RegLocator表,或者使用InstallShield System搜索向导为您填充表。当然,您可以改为创建自定义操作脚本或DLL来为您读取注册表数据。(您可以将条件未安装附加到您要仅针对首次安装运行的操作上,并将条件已安装用于仅应在维护操作期间运行的操作)

    前面提到的例外是MSI属性USERNAME,COMPANYNAME和ProductID的值,这些值可以通过MsiGetUserInfo API函数使用。以及MsiGetProductInfo API函数提供的ProductVersion和大多数添加或删除程序设置的值。

    通常的要求是保存主产品安装目录的值,该目录通常存储在INSTALLDIR属性中,以便在维护或更新操作期间可以使用该值。内置属性ARPINSTALLLOCATION的值会自动写入目标系统的注册表,并且可以使用MsiGetProductInfo函数使用。要将ARPINSTALLLOCATION设置为INSTALLDIR的值,可以使用源ARPINSTALLLOCATION和目标[INSTALLDIR]创建一个属性设置(Type-51)自定义操作,在标准CostFinalize操作之后按执行顺序对其进行调度。如果使用InstallShield创建项目,则会自动包含此类自定义操作。


    以上内容对您使用InstallShield是否有帮助?如果您有其他的疑惑或者建议都可以在评论区留言。

推荐文章:

MSI功能和组件的使用

InstallShield v2019最新更新说明

=================================================

如果您想要购买正版授权InstallShield,可以联系咨询相关问题。

关注慧聚IT微信公众号☟☟☟,了解产品的最新动态及最新资讯。

1561953111.jpg


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@pclwef.cn

文章转载自:

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP