最近项目需要实现报表功能,平衡各方面的因素,还是使用Crystal Report(水晶报表)

下载较新版本: http://downloads.businessobjects.com/akdlm/cr4vs2010/CRforVS_13_0_21.exe

下载后解压,使用管理员权限安装。

选择语言,点击下一步,同意SAP BUSINESSOBJECTS license Agreement:

选中Yes,install 64-bit runtime选项。
点击Finish按钮,继续安装。

安装结束,所有安装窗口自动关闭。

打开你的项目,参考下面几个类:

打开Web.Config文档,需要配置Crystal Report:

<configSections>
<sectionGroup name="businessObjects">
<sectionGroup name="crystalReports">
<section name="rptBuildProvider" type="CrystalDecisions.Shared.RptBuildProviderHandler, CrystalDecisions.Shared, Version=13.0.2000.0, Culture=neutral, PublicKeyToken=692fbea5521e1304, Custom=null" />
<section name="crystalReportViewer" type="System.Configuration.NameValueSectionHandler" />
</sectionGroup>
</sectionGroup>
</configSections>

configSections Source Code

<assemblies>
<add assembly="CrystalDecisions.Web, Version=13.0.3500.0, Culture=neutral, PublicKeyToken=692FBEA5521E1304"/>
<add assembly="CrystalDecisions.Shared, Version=13.0.3500.0, Culture=neutral, PublicKeyToken=692FBEA5521E1304"/>
<add assembly="log4net, Version=1.2.10.0, Culture=neutral, PublicKeyToken=692FBEA5521E1304"/>
<add assembly="CrystalDecisions.ReportSource, Version=13.0.3500.0, Culture=neutral, PublicKeyToken=692FBEA5521E1304"/>
<add assembly="CrystalDecisions.ReportAppServer.Controllers, Version=13.0.3500.0, Culture=neutral, PublicKeyToken=692FBEA5521E1304"/>
<add assembly="CrystalDecisions.ReportAppServer.DataDefModel, Version=13.0.3500.0, Culture=neutral, PublicKeyToken=692FBEA5521E1304"/>
<add assembly="CrystalDecisions.CrystalReports.Engine, Version=13.0.3500.0, Culture=neutral, PublicKeyToken=692FBEA5521E1304"/>
</assemblies>

assemblies Source Code

<businessObjects>
<crystalReports>
<rptBuildProvider>
<add embedRptInResource="true" />
<add extension=".rpt" type="CrystalDecisions.Web.Com
pilation.RptBuildProvider, CrystalDecisions.Web, Version=13.0.2000.0, Culture=neutral, PublicKeyToken=692fbea5521e1304"/>
</rptBuildProvider>
</crystalReports>
</businessObjects>

businessObjects Source Code

接下来,为ASP.NET MVC项目添加一页网页是asp.net 的ASPX,网页名为CurrencyReport.aspx,它自带有CurrencyReport.aspx.cs如下图。

对这页网页暂时不需添加任何代码,稍后创建好.Rpt报表后再来写代码。

现在开始创建.rpt水晶报表:

报表创建完毕,此时打开上面创建的ASPX网页。

再打开.aspx.cs代码页,编写加载水晶报表程序:

 string reportPath = Server.MapPath("CurrencyReport.rpt");
ReportDocument repDoc = new ReportDocument(); try
{
if (!File.Exists(reportPath))
{
Response.Write("指定的报表不存在。 \n");
} repDoc.Load(reportPath); repDoc.SetDatabaseLogon("username", "password", "127.0.0.1", "DBname", true);
this.CrystalReportViewer1.ToolPanelView = CrystalDecisions.Web.ToolPanelViewType.None;
this.CrystalReportViewer1.HasToggleGroupTreeButton = false;
this.CrystalReportViewer1.ReportSource = repDoc; }
catch (Exception ex)
{
Response.Write(ex.Message);
}

Source Code

为程序添加水晶报表完成,我们运行程序,结果如下:

什么内容也没有显示,按F12查看,还有crv.js加载失败和bobj is not defind错误。

经过研究与测试,我们还做少一步动作。前往电脑C驱动器:C:\inetpub\wwwroot把aspnet_client整个目录拷贝至项目的根目录之下。

再次运行程序:

数据还是没有显示,水晶报表需要输入连接数据安全信息。

解决这个问题,需要打开加载水晶报表的程序,添加一个方法SetDatabaseLogon,并赋其参数

再次刷新网页,上面的对话框消失,报表已经正常显示了》

最新文章

  1. 项目Windows服务安装命令:
  2. eclipse 改变字体大小
  3. DimDate
  4. CentsOS7 网络自动启动
  5. QQ粘性效果
  6. wget命令解析
  7. inuitcss
  8. C#系列之值类型和引用类型
  9. UILabel + 导入字体
  10. MySQL IO线程及相关参数调优
  11. Cocos2D旋转炮塔到指定角度(二)
  12. MySQL之路 ——1、安装跳坑
  13. tensorflow模型在实际上线进行预测的时候,使用CPU工作
  14. vijos1448校门外的树
  15. 【教程】新手如何制作简单MAD和AMV,学不会那都是时辰
  16. jQuery中first-child与first选择器区别
  17. 快速掌握Gif动态图实现代码
  18. 通过Hadoop安全部署经验总结,开发出以下十大建议,以确保大型和复杂多样环境下的数据信息安全。
  19. QT treewidget 右键菜单
  20. Microsoft Visual Studio 2013 已停止工作的解决方法

热门文章

  1. 记录Queue插入的时候报错
  2. redis各类错误可能的解决方案
  3. php 通过扫描二维码关注公众号
  4. Pyton:类变量,实例变量,类对象,实例对象
  5. laravel项目安装与重要目录文件说明(一)
  6. mybatis学习笔记1.零碎记录
  7. 解决Tomcat version 7.0 only supports J2EE 1.2, 1.3, 1.4, and Java EE 5 and 6 Web modules
  8. python 字典 拼接SQL语句
  9. vue的一些注意点
  10. Chapter5_初始化与清理_数组初始化与可变参数列表