本文转载自:
这两天搞安装包真心坎坷,一个问题接一个问题,先是为了实现自定义动作现啃vbs,后面又是安装过程老是报错:
各种搜索、各种尝试,总算搞掂,积累了些经验,分享一下。
首先CR for VS2010的所有东东都在这里:
简单说一说资源下载表的情况,资源表如图(敢情都出到SP10了,我用的是13.0.9.1312):
每列代表一类资源,每行代表一个版本,我仅就我知道的资源类别介绍一下:
Install Executable: 我理解是完整版,包括VS插件、报表设计器、运行环境等所有东西,装上后就可以在VS中创建CR报表了。适用于开发机;
MSI 32/64 Bit: 运行环境独立安装包,分别适用于32/64平台。就是装在客户电脑上的东东,下文我所谓的MSI整合法就是指这个;
MSM 32 Bit: 也是运行环境,只不过是用来合并在安装包中的,不能独立安装。看起来只有32位版;下文我所谓的MSM合并法就指它
别的什么ClickOnce、WEB XML Dep..啥的我没用过,不清楚。
一、MSM合并法
这是我最先选择的方式,也正是老出现上述报错的方式。
优点:正统打包方式;得到的安装包体积相比MSI整合法小接近30M
缺点:不管系统是否已经有CR组件,安装时长都不短(我的环境是起码2min+),光软件部分的安装过程其实是很快的,等于大部分安装时间都是部署CR组件去了
另外有一点我现在懒得确认了,就是该方式在软件卸载时会不会连CR组件一起卸载不确定,以后有机会再试。
该方法的官方文档在此:
E文好的童鞋照着做应该就成了,我主要说一下我认为的关键点:
1、CR的msm文件最少只需并一个即可,就是CRRuntime_13_x.msm,40M多那个,其余的是语言包和一个CRRuntime_maps_13_x.msm,maps这个不知道干嘛的,反正我没并也不影响使用。语言包的话按需并就是。
2、另外要并4个VC80的msm,分别是:Microsoft_VC80_ATL_x86.msm、Microsoft_VC80_CRT_x86.msm、Microsoft_VC80_MFC_x86.msm、Microsoft_VC80_MFCLOC_x86.msm。这个在官文的截图中有体现。关键问题是,装VS2010后,在【C:\Program Files (x86)\Common Files\Merge Modules】中只会有VC100版的msm,上哪弄VC80的着实让我折腾了一下,后来是在虚拟机中装个VS2005才得到的,已上传至网盘: 。下载后放到上述Merge Modules目录中即可。
3、另一个关键是,客户机要装这个 ,即VC++2005 SP1分发包的ATL更新。扯一下,VC++05的分发包我知道的有这么4个:VC++05、VC++05 SP1、VC++05 SP1 ATL、VC++05 SP1 MFC,根据经验,SP1包含RTM,ATL更新和MFC更新又都包含SP1,但ATL和MFC应该互不包含(从文件大小判断)。总之本例来说,只需且必须在客户机装ATL更新即可,之前老报那个错就是因为客户机只装了RTM或SP1的原因,这个在官文中也有提及。
完成以上3点,MSM法就没问题了。说实话弄清楚以上关键点煞费周折,容我张狂,网上说CR部署的文章不少,但都没叽歪到重点,不知道是那些作者RP好没遇到问题还是咋的。
二、MSI整合法
该方法其实原理就是,先装CR运行环境独立安装包(见上文资源表说明部分,下文简称CR MSI,下文说的安装包都指软件安装包),再装软件本身,跟手动分开装一样的效果,只不过整合到安装包中的话,是由安装包调用CR MSI进行安装,而不是人工安装。照例说一说我认为的优缺点:
优点:不折腾。由于CR MSI是可以独立安装的,它已经集成了VC80 msm、ATL啥的,只要它装完就已经可以支撑报表运行;另外就是这种方法可以写条件判断是否已装CR组件,如果已装就不装了,这样能大大缩短整个安装时长
缺点:安装包比MSM合并法大近30M。原因当然是CR MSI本身就有70M多的个头,比40M的CRRuntime_13_x.msm+单个语言包就大了那么多
此外这种方法安装完成后,在控制面板【添加/删除程序】中会体现CR运行环境:
意味着可以独立卸载它,这个是优/缺点各人看待。
言归正传,具体整合方法,因打包软件不同而不同,所以不好详说。我用的是Advanced Installer(简称AI),是在先决条件中加入CR MSI,加入后AI能智能识别并填好安装条件什么的,就是在客户机还没装CR MSI时,安装过程就会执行CR MSI,否则不执行,这样在已装CR运行环境的机器上,整个安装过程就很快。话说无论是MSM法还是MSI法,只要是没装CR的机器,部署CR组件的时间都挺长的,这尼玛水晶报表更新到这一版就这点不好,早期版本的安装都是很快的,这一版没个几分钟装不下来。所以正是因为安装时长这个问题,在我解决msm法后,毅然决然还是选用MSI法,原因就是后者可以判断,在已装过的情况下可以不装(例如重装软件),而前者就是不管装没装过都要耗一下,反正我是挺在意安装时长这事的。
三、手动MSI法
这条完全是凑数的,它就是上面第二法的手动版,没技术含量,不过作为列举部署方法的文章来说,它的确也是方法之一,并且该方法可以大大缩小安装包的体积,省70M哦亲。容我啰嗦,此法在部署时需要扔两个文件到客户机,自然就是CR MSI和软件安装包这俩货了,完了先装CR MSI,再装软件。如果客户机已经装过CR,只需传一个不带任何添加剂的绿色无公害安装包过去即可,这在ADSL翔上行的年代,还是有点惬意的,这也是此法写出来的缘由。
Anyway~折腾了几天,这鸟包总算打好,开始下一个项目...
- 文毕 -