前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >水晶报表13.x(Crystal Reports for VS2010)的安装部署经验

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

作者头像
AhDung
发布于 2018-09-13 03:31:58
发布于 2018-09-13 03:31:58
2K0
举报
文章被收录于专栏:AhDungAhDung

这两天搞安装包真心坎坷,一个问题接一个问题,先是为了实现自定义动作现啃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~折腾了几天,这鸟包总算打好,开始下一个项目...

- 文毕 -

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2014-08-14 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Composer (三) -- 自动加载
composer (一) – 依赖管理 前面这篇文章介绍了 composer 对依赖的安装及更新。
caoayu
2021/02/04
1.1K0
PSR-4规范:自动加载
虽然在[PSR-4-Meta]中指出PSR-4是对PSR-0规范的补充而不是替换,但是在[PSR-0]中已经写到PSR-0于2014.10.21被废弃,并在[PSR-4-Meta]中详细写明了PSR-0的不足,已经不能满足面向package的自动加载。
超级小可爱
2023/05/21
5350
Laravel框架中composer自动加载的实现分析
自动加载允许你通过即用即加载的方式来加载需要的类文件,而不用每次都写繁琐的require 和include语句。因此,每一次请求的执行过程都只加载必须的类,也不不要关心类的加载问题,只要需要的时候直接使用即可。
用户8832582
2021/07/13
9150
PHP规范PSR0和PSR4的理解
一、PSR0简介 下文描述了若要使用一个通用的自动加载器(autoloader),你所需要遵守的规范: 一个完全标准的命名空间(namespace)和类(class)的结构是这样的:\<Vendor Name>\(<Namespace>\)*<Class Name> 每个命名空间(namespace)都必须有一个顶级的空间名(namespace)("组织名(Vendor Name)")。 每个命名空间(namespace)中可以根据需要使用任意数量的子命名空间(sub-namespace)。 从文件系统中加载源文件时,空间名(namespace)中的分隔符将被转换为 DIRECTORY_SEPARATOR。 类名(class name)中的每个下划线_都将被转换为一个DIRECTORY_SEPARATOR。下划线_在空间名(namespace)中没有什么特殊的意义。 完全标准的命名空间(namespace)和类(class)从文件系统加载源文件时将会加上.php后缀。 组织名(vendor name),空间名(namespace),类名(class name)都由大小写字母组合而成。 参考:http://www.php-fig.org/psr/psr-0/ 以下,列出PSR0构建的规范类的几种形式:
猿哥
2019/11/28
1.3K0
PHP规范PSR0和PSR4的理解
[CodeIgniter4]概述-自动加载文件
每个应用程序都包含许多位于不同位置的类。该框架提供了用于核心功能的类。您的应用程序将具有许多库,模型和其他实体,以使其正常运行。您可能有项目正在使用的第三方类。跟踪每个文件的位置,然后将该位置硬编码成一系列文件,这requires()是一件非常麻烦的事情,而且容易出错。这就是自动装带器的用武之地。
landv
2020/03/05
1.7K0
PHP的类自动加载机制
在PHP开发过程中,如果希望从外部引入一个class,通常会使用include和require方法,去把定义这个class的文件包含进来。这个在小规模开发的时候,没什么大问题。但在大型的开发项目中,这么做会产生大量的require或者include方法调用,这样不因降低效率,而且使得代码难以维护,况且require_once的代价很大。
黄规速
2022/04/14
8110
Composer (四) -- 其他自动加载方法
composer 自动加载 这篇写了自动加载及自定义类使用 psr4 加载。下面介绍下另两种自动加载的方式。1. classmap. 2 files
caoayu
2021/02/22
5520
【译】现代化的PHP开发--PSR规范
来源/https://www.startutorial.com/articles/view/modern-php-developer-psr
Lemon黄
2019/10/08
6020
thinkphp自动加载机制
PHP的自动加载机制个人感觉使用起来还是很方便的。关于PHP的自动加载机制,其核心的方法是__autoload()和spl_autoload_register()两个函数。
PM吃瓜
2019/08/13
1.3K0
PHP自动加载与composer自动加载
当我们编写面向对象的程序时,通常是将类分别放在不同的文件中。但这样一来,当我们调用其他类的时候,则需要先手动引入该文件(否则会因为当前程序中没有该类名的类而报错)
仙士可
2019/12/19
2K0
PHP自动加载与composer自动加载
深入学习Composer原理(三)
首先恭喜大家,包括我自己,坚持到了现在。这篇文章之后,Composer的基础原理就清晰明了咯。也就是说,Composer所利用的正是spl_autoload_register()和PSR4规范,然后通过线上服务器存储包,来实现包管理的功能。spl_autoload_register()的作用我们已经清楚了,主要就是动态加载我们所需要的文件。然而我们的文件不可能都乱七八糟的随便找个目录放下,然后注册一堆的spl_autoload_register()来加载吧,要真这么写,估计你的老板会废了你。在这个时候,PSR路径规范的作用就显示出来咯!!
硬核项目经理
2019/08/06
4990
深入学习Composer原理(三)
PHP Composer 的自动加载
PHP 的 autoload 机制,可以在使用一个未导入的类时动态加载该类,从而实现延迟加载和管理依赖类文件的目的。
菜皮日记
2023/12/18
2880
PHP Composer 的自动加载
深入理解composer自动加载原理
Composer 作为 PHP 的包管理工具,为 PHPer 们提供了丰富的类库,本文来一步步剖析 Composer 的原理
憧憬博客
2020/07/21
1.4K0
深入理解composer自动加载原理
Laravel5.2之Composer自动加载
说明:本文主要以Laravel的容器类Container为例做简单说明Composer的自动加载机制。
botkenni
2022/03/24
3.6K0
Laravel5.2之Composer自动加载
介绍PHP的自动加载
include 和 require 是PHP中引入文件的两个基本方法,但是每个脚本的开头,都需要包含(include)一个长长的列表总是不好的,所以 PHP 使用了自动加载器来解决这个问题。
_春华秋实
2018/09/28
1.2K0
介绍PHP的自动加载
composer 实现自动加载原理
一般在框架中都会用到composer工具,用它来管理依赖。其中composer有类的自动加载机制,可以加载composer下载的库中的所有的类文件。那么composer的自动加载机制是怎么实现的呢?
lin_zone
2018/08/15
9420
Composer
Composer是PHP中用来管理依赖(dependency)关系的工具。你可以在自己的项目中声明所依赖的外部工具库(libraries),Composer会帮你安装这些依赖的库文件。 如果A依赖B的版本是1.0.0,如果C依赖B的版本是2.0.0,项目当中是否没导入同一包用不同版本的。 PHP的自动加载可以使用__autoload()和spl_autoload_register()两种机制,但官方推荐使用和spl_autoload_register 更多参考:http://php.net/manual/
苦咖啡
2018/04/28
1.3K0
php自动加载
平时总使用composer,反而对自动加载的知识有些陌生啦,重新梳理下php中自动加载的知识
码缘
2020/07/21
2.1K0
php自动加载
PHP 自动加载
开始的时候, 如果想在一个php文件中使用其它文件的类或方法, 需要通过include/require方法将文件包含进来. 这种方法的缺点也很明显:
烟草的香味
2019/07/25
1.9K0
相关推荐
Composer (三) -- 自动加载
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文