水晶报表13.x(Crystal Reports for VS2010)的安装部署经验

这两天搞安装包真心坎坷,一个问题接一个问题,先是为了实现自定义动作现啃vbs,后面又是安装过程老是报错:

各种搜索、各种尝试,总算搞掂,积累了些经验,分享一下。

首先CR for VS2010的所有东东都在这里:http://scn.sap.com/docs/DOC-7824

简单说一说资源下载表的情况,资源表如图(敢情都出到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组件一起卸载不确定,以后有机会再试。

该方法的官方文档在此:

http://wiki.scn.sap.com/wiki/display/BOBJ/Using+Crystal+Reports+for+Visual+Studio+2010+Merge+Modules+(MSM)+to+create+a+Setup+project

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才得到的,已上传至网盘:http://pan.baidu.com/s/1dDELlWt。下载后放到上述Merge Modules目录中即可。

3、另一个关键是,客户机要装这个http://www.microsoft.com/zh-CN/download/details.aspx?id=14431,即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~折腾了几天,这鸟包总算打好,开始下一个项目...

- 文毕 -

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏闻道于事

商城项目回顾整理(一)前台页面布局

登录页面: 1 <%@ page language="java" contentType="text/html; charset=utf-8" 2 ...

3893
来自专栏机器人网

无人机的通用语言,你懂吗?

小型无人机通信协议MAVLink解析 0、目录 1、概述 2、数据帧介绍 3、消息(PAYLOAD)介绍 4、举个栗子 5、传输性能介绍 6、缩略语 1、概述 ...

4196
来自专栏晨星先生的自留地

看zwell怎么带我解决方程式poc的bug

1862
来自专栏NetCore

复杂而艰辛的重构之路--起步

你有没有试过,当你踏入一个新的公司,看到了几千几万几十万代码的时候,那种崩溃的感觉? 代码多不可怕,怕的是代码的可读性、维护性、扩展性是如此之差,这时候该怎么办...

2079
来自专栏AndroidTv

AndroidTv Home界面实现原理(一)——Leanback 库的使用

接下去应该是梳理一下 Android Tv 主界面实现原理及解析的一个系列博客了,大体上的安排是先介绍 Google 官方提供的 Leanback 库的使用,如...

4417
来自专栏牛客网

C++后台腾讯WXG实习面经(已拿offer)

2065
来自专栏玩转全栈

flutter使用platform-channels制作插件

一、flutter使用platform-channels制作插件是否是一种完美的体验?

4574
来自专栏极客生活

真正好用的python库

这个库是我安装完python环境后第一个安装的库,装上这个库再开始写代码才有底气,作者 Kenneth Reitz 是公认python领域代码写的最好的两个人之...

1243
来自专栏QQ音乐技术团队的专栏

OpenSL ES那些事

本次分享主要是将JNI层的声音采集,传输以及播放过程做相应介绍,若是大家有更好的优化建议,欢迎指教。

2.3K7
来自专栏北京马哥教育

Python爬虫爬取美剧网站

一直有爱看美剧的习惯,一方面锻炼一下英语听力,一方面打发一下时间。之前是能在视频网站上面在线看的,可是自从广电总局的限制令之后,进口的美剧英剧等貌似就不在像以前...

1670

扫码关注云+社区

领取腾讯云代金券