关于InstallShield Projects[转]

关于   InstallShield   Projects:   
    
  InstallShield   可以创建三种类型的项目(Project)   
  1、InstallScript   Project   
  2、InstallScript   MSI   Project   
  3、Basic   MSI   Project   
  前者完全是   InstallShield   自己的功能实现   
  后两者基于   Windows   Installer,InstallScript   MSI   Project   在   Windows   Installer   基础上提供了一些   InstallShield   自己的扩展功能支持。   
  Basic   MSI   Project   完全基于   Windows   Installer,制作出来的安装程序完全符合W2K相关标准,因此比较适合在   Windows   域中使用。   
  InstallScript   MSI   Project   制作出来的安装程序中可以见到   xxx.msi   文件。该   msi   文件离开了   InstallShield   的   engine   无法独立运行。而   Basic   MSI   Project   的   msi   文件是可以独立运行的(在域里面就知道好处了)   :)   
    
  InstallShield   做补丁的机制也与   MSI   补丁有区别。   
    
    
    
  关于版本升级补丁和热修复补丁:   
    
  说到做补丁,也有很多不同的方法   
  1、很多如网络游戏、瑞星等,安装了某一个版本比如   1.05,之升级动作是通过检查有否更新的文件——验证文件数字签名(比如MD5摘要信息),但升级后的软件是哪个版本呢?   
    
  一个软件的版本实际上是组成该版本的所有特定版本文件的集合。   
    
  1的方式可以用Winzip/Winrar等等做一个自解压文件,或者在线升级程序下载新的文件覆盖本地文件,甚至可以用补丁制作工具做成exe,在本地执行以二进制方式修改本地文件等等方式来实现。我见过瑞星工程师在域里就是用一个启动脚本在客户端运行服务器共享目录里的批处理复制文件覆盖本地文件...   
    
  2、Hotfix   
  类似于Windows的hotfix/servicepack这样的方式的补丁,则是一种非线性的升级方式。与方式1类似,但hotfix方式并不是“升级”——Upgrade,更准确地说应该是“补丁”——patch。也就是说,在版本   V1.05   之上有若干补丁,你可以装这些补丁(微软的Service   Pack往往包含了前面发布的相关Hotfix和一些其他的工具)中的某一些。   
    
  参考“一个软件的版本实际上是组成该版本的所有特定版本文件的集合”,可知这个概念不会影响到当前的“版本”这一概念。   
    
  这一点,与1相似。不同的是,技术实现上你可以看到每一个hotfix实际上是一个独立的product   installation。   
  最典型地:每装一个   hotfix,添加删除程序中会多一个条目。如果允许的话(比如hotfix之间没有互相影响),可以单独删除某个hotfix。   
    
  3、Transform   
  从上面看可以知道,Hotfix或者SP并不是将你的软件升级成新版本(或者仅仅升级Build),那么要把V1.05版本升级到2.0怎么做呢?   
  InstallShield   MSI   Project/Basic   MSI   Project   的   patch   实际上就是   Windows   Installer   机制中的   trasform。   
  制作出来的“升级”补丁,也就是“升级包”。   
    
  比如在2.0版的安装程序中针对1.05做了一个升级补丁   Update1.05To2.0.msi/Update1.05To2.0.exe,运行之后,你会发现添加删除程序中并没有增加一个新的“产品”项,而原来的   1.05   的项变成了   2.0   的。   
  这才是真正意义上的升级。   
    
  因此,可以把3这种方法看作是   
  1.05   版本   +   1.05-2.0   版本所需要做出的“所有”改变(不仅仅是文件更新、新增/删除文件,甚至可能有注册表信息、快捷方式甚至数据库配置等等的更改)的集合。假如   1.05   的所有   hotfix   都装了(或者ServicePack),就相当于   2.0   的话,那么你可以理解为   所有   hotfix(sp)加起来就是升级包,呵呵。   
    
  InstallShield   提供的补丁制作功能很不错,我每发布一个新版本的客户端,会发布一个新版本的完整安装程序,然后发布一个个针对指定版本的升级包(也可以在一个升级包中支持对多个版本的升级,但文件可能稍大)。   
    
    
  补充说明:   
  在   InstallShield   有两个功能:   
  Upgrades   
  Patch   Design   
  前者主要用于制作全新的完整的安装(升级)包,运行时如果当前计算机上没有旧版本,则执行完整安装。如果有,则升级原有安装。   
  后者主要制作版本升级补丁,比前者小,更有针对性,比较适合在网络上发布或者用于在线升级。但假如在从一个版本到另外一个版本的升级过程中需要移动某些文件的位置,则一定要用Upgrade方式,而非Patch方式。   
  另外,help中提到   Patch   方式不能制作   InstallScript   MSI   Project   的   Major   升级,只能用Upgrade方式。但在实际应用中,我的确用一个   Patch   将客户端软件从   2.5   Build   74   升级到了   3.0   Build   76   版本(2.50.0074   到   3.00.0076)

posted @ 2013-08-15 10:34  想飞的水  阅读(704)  评论(0编辑  收藏  举报