Stimulsoft Reports.Web,是一款可以直接在Web中编辑报表的报表工具

web项目技术框架mvc4+easyui+knockoutjs

1.在项目中添加引用

Stimulsoft.Base.dll,

Stimulsoft.Report.dll,

Stimulsoft.Report.Web.dll,

Stimulsoft.Report.WebDesign.dll

2.定义模板文件:新建web窗体文件report.aspx

前台代码:

  1. <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="report.aspx.cs" Inherits="PE.IEM.Web.report" %>
  2. <%@ Register Namespace="Stimulsoft.Report.Web" TagPrefix="cc1" Assembly="Stimulsoft.Report.Web, Version=2012.3.1500.0, Culture=neutral, PublicKeyToken=096a9279a87304f1"%>
  3. <%@ Register Namespace="Stimulsoft.Report.Web" TagPrefix="cc2" Assembly="Stimulsoft.Report.WebDesign, Version=2012.3.1500.0, Culture=neutral, PublicKeyToken=096a9279a87304f1"%>
  4.  
  5. <!doctype html>
  6. <html>
  7. <head runat="server">
  8. <title></title>
  9. </head>
  10. <body style="background-color: #e8e8e8">
  11. <form id="form1" runat="server">
  12. <div style="width: 960px;margin: 0 auto;">
  13. <cc1:StiWebViewer ID="StiWebViewer1" runat="server" GlobalizationFile="/Content/page/reports/Localization/zh-CHS.xml" ShowDesignButton="True" onreportdesign="StiWebViewer1_ReportDesign" Theme="Office2010" BackColor="#e8e8e8"/>
  14. <cc2:StiWebDesigner ID="StiWebDesigner1" runat="server" LocalizationDirectory="/Content/page/reports/Localization/" Localization="zh-CHS" onsavereport="StiWebDesigner1_SaveReport" />
  15. </div>
  16. </form>
  17. </body>
  18. </html>

后台代码:

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Configuration;
  4. using System.IO;
  5. using System.Linq;
  6. using System.Web;
  7. using System.Web.UI;
  8. using System.Web.UI.WebControls;
  9. using Stimulsoft.Report;
  10.  
  11. namespace PE.IEM.Web
  12. {
  13. public partial class report : System.Web.UI.Page
  14. {
  15. /// <summary>
  16. /// 将获取的报表放在阅读器中显示
  17. /// </summary>
  18. /// <param name="sender"></param>
  19. /// <param name="e"></param>
  20. protected void Page_Load(object sender, EventArgs e)
  21. {
  22. StiWebViewer1.Report = GetReport();
  23. }
  24.  
  25. /// <summary>
  26. /// 编辑报表
  27. /// </summary>
  28. /// <param name="sender"></param>
  29. /// <param name="e"></param>
  30. protected void StiWebViewer1_ReportDesign(object sender, EventArgs e)
  31. {
  32. StiWebDesigner1.Design(GetReport());
  33. }
  34.  
  35. /// <summary>
  36. /// 保存报表
  37. /// </summary>
  38. /// <param name="sender"></param>
  39. /// <param name="e"></param>
  40. protected void StiWebDesigner1_SaveReport(object sender, Stimulsoft.Report.Web.StiWebDesigner.StiSaveReportEventArgs e)
  41. {
  42. var report = e.Report;
  43. report.Save(GetReportPath());
  44. }
  45.  
  46. /// <summary>
  47. /// 获取报表
  48. /// </summary>
  49. /// <returns></returns>
  50. private StiReport GetReport()
  51. {
  52. var report = new StiReport();
  53. //根据路径加载报表文件
  54. report.Load(GetReportPath());
  55. //动态改变数据库连接
  56. ChangeConnectString(report);
  57. //设置参数等
  58. report.Compile();
  59. SetReportParamaters(report);
  60.  
  61. return report;
  62. }
  63.  
  64. private void SetReportParamaters(StiReport report)
  65. {
  66. var dataSource = report.CompiledReport.DataSources;
  67. foreach (Stimulsoft.Report.Dictionary.StiDataSource ds in dataSource)
  68. {
  69. var param = Request.QueryString;
  70. foreach (string key in param.Keys)
  71. {
  72. if (!ds.Parameters.Contains(key)) continue;
  73. var p = ds.Parameters[key];
  74. var v = param[key];
  75. p.ParameterValue = v;
  76. }
  77. }
  78. }
  79.  
  80. private string GetReportPath()
  81. {
  82. var path = String.Format("~/Areas/{0}/Reports/{1}.mrt",Request["area"], Request["rpt"]);
  83. path = Server.MapPath(path);
  84. if (!System.IO.File.Exists(path))
              //如果报表文件不存在,返回默认的报表文件
  85. path = Server.MapPath("~/Content/page/reports/helloworld.mrt");
  86. return path;
  87. }
  88.  
  89. private void ChangeConnectString(StiReport report)
  90. {
  91. foreach (Stimulsoft.Report.Dictionary.StiSqlDatabase item in report.Dictionary.Databases)
  92. {
  93. var prefix = item.Name.Split('_')[];
  94. item.ConnectionString = ConfigurationManager.ConnectionStrings["sqlConnection"].ConnectionString;
  95. }
  96. }
  97. }
  98. }

就是把阅读器和编辑器放在模板中

3.注册路由:在App_Start文件夹的RouteConfig中注册报表模板访问路径

routes.MapPageRoute("Report", "report", "~/Content/page/report.aspx");

4.js调用:调用报表模板访问路径并传递2个参数,根据传递的参数去查找并加载指定报表文件

  1. this.printClick = function () {
       parent.wrapper.addTab.apply(this,{'打印报表', '/report?area=XX&rpt=helloworld', 'icon-printer_color'});
    };

5.效果展示

web报表工具Stimulsoft Reports.Web在mvc项目中使用的更多相关文章

  1. 设计与开发一款简单易用的Web报表工具(支持常用关系数据及hadoop、hbase等)

    EasyReport是一个简单易用的Web报表工具(支持Hadoop,HBase及各种关系型数据库),它的主要功能是把SQL语句查询出的行列结构转换成HTML表格(Table),并支持表格的跨行(Ro ...

  2. web报表工具FineReport使用中遇到的常见报错及解决办法(二)

    web报表工具FineReport使用中遇到的常见报错及解决办法(二) 这里写点抛砖引玉,希望大家能把自己整理的问题及解决方法晾出来,Mark一下,利人利己. 出现问题先搜一下文档上有没有,再看看度娘 ...

  3. web报表工具FineReport常用函数的用法总结(日期和时间函数)

    web报表工具FineReport常用函数的用法总结(日期和时间函数) 说明:凡函数中以日期作为参数因子的,其中日期的形式都必须是yy/mm/dd.而且必须用英文环境下双引号(" " ...

  4. web报表工具FineReport最经常用到部分函数详解

    之前分别列出来了finereport常用的文本.时间函数的解释,这里应广大朋友的要求,整理了finereport最常用到的一些函数! SUM SUM(number1,number2,-):求一个指定单 ...

  5. web报表工具FineReport经常使用函数的使用方法总结(日期和时间函数)

    web报表工具FineReport经常使用函数的使用方法总结(日期和时间函数) 说明:凡函数中以日期作为參数因子的,当中日期的形式都必须是yy/mm/dd.并且必须用英文环境下双引號(" & ...

  6. 开源报表工具太复杂?不如用这款免费web报表工具

    随着信息系统的高速发展,报表平台逐渐成为了信息系统当中最为核心和重要的功能模块.报表工具有助于将原始数据可视化显示,使决策者或者相关人员能够一览整体的数据趋势,完整的报表解决方案会提供多样的表格数据展 ...

  7. 最锋利的Visual Studio Web开发工具扩展:Web Essentials详解

    原文:最锋利的Visual Studio Web开发工具扩展:Web Essentials详解 Web Essentials是目前为止见过的最好用的VS扩展工具了,具体功能请待我一一道来. 首先,从E ...

  8. 在ASP.NET MVC项目中使用极验验证(geetest)

    时间 2016-03-02 18:22:37 smallerpig 原文  http://www.smallerpig.com/979.html 主题 ASP.NET MVC   geetest开发体 ...

  9. 转 mvc项目中,解决引用jquery文件后智能提示失效的办法

    mvc项目中,解决用Url.Content方法引用jquery文件后智能提示失效的办法   这个标题不知道要怎么写才好, 但是希望文章的内容对大家有帮助. 场景如下: 我们在用开发开发程序的时候,经常 ...

随机推荐

  1. cvc-complex-type.2.4.c: The matching wildcard is strict, but no declaration can be found for element 'mvc:annotation-driven'.

    spring 配置文件报错报错信息:cvc-complex-type.2.4.c: The matching wildcard is strict, but no declaration can be ...

  2. [LeetCode] Find the Difference 寻找不同

    Given two strings s and t which consist of only lowercase letters. String t is generated by random s ...

  3. Android开发之画图的实现

    Android开发之画图的实现    四天前上完安卓的第一节课,真的是一脸懵逼,尽管熊哥说和java是差不多的,然而这个包和那个包之间的那些转换都是些什么鬼呀!!!但是四天的学习和操作下来,我觉得安卓 ...

  4. Android中关于cpu/cpuset/schedtune的应用

    Android中关于cpu/cpuset/schedtune的应用都是基于进程优先级的,根据不同优先级划分进程类型.AMS(ActivityManagerService)和PMS(PackageMan ...

  5. Python学习--Python 环境搭建

    Python环境搭建 Python是跨平台的编程语言,可应用于Windows.Linux.Mac OS X.你可以通过终端窗口输入"python"命令来查看本地是否安装了Pytho ...

  6. Android组件化

    附:Android组件化和插件化开发 App组件化与业务拆分那些事 Android项目架构之业务组件化 Android组件化核心之路由实现 Android组件化开发实践

  7. 【USACO 3.2】Magic Squares

    题意 4*2个格子分别为 1234 8765 的魔板有3种操作,A:上下两排互换,B:最后一列放到第一列前面,C:中间四个顺时针旋转1格. 现在给出目标状态,找出最少步数可从原始状态到达目标状态,且输 ...

  8. NPOI导出数据,设置格式,锁定单元格

    代码包括: 1:导出多个sheet    2:设置单元格格式   3:合并单元格   4:下拉框选项   5:输入数字限制   6:锁定单元格 static void Main(string[] ar ...

  9. C# 扩展系统类方法

    1.声明扩展方法的步骤:类必须是static,方法是static 2.第一个参数是被扩展的对象,前面标注this 3.使用扩展方法的时候必须保证扩展方法类已经在当前代码中using 例子:using ...

  10. [半转]1px边框 移动端

    半转的意思是借鉴参考,搬砖,加了一些自己的想法. 在移动端里,因为存在2倍像素的问题,所以很多时候,移动端上的1px边框并不是意义上的.从下图红色框看到dpr:2.0 ,表示1px等于2倍的物理像素. ...