`
w800927
  • 浏览: 120034 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

转:birt报表

阅读更多

1.概述

网站: http://www.eclipse.org/birt/phoenix/

BIRT报表 拥有和Dreamweaver一般的操作界面,可以像画table一样画报表,生成图片,导出Excel,html分页样样齐全,样式和script设置简单,貌似还有OLAP导航功能,JasperReport注定要被打入冷宫了。

特别留意,SpringSide里仿照Spring集成JasperReport的做法,集成了Birt View。

另外特别Demo了把查询语句统一写在SaleReportManager里,对查询语句综合处理与重用,而不是默认的在每个模版文件里面写SQL。

学习资料:

     1.Birt的IBM DW的中文教程:http://www-128.ibm.com/developerworks/cn/opensource/os-ecl-birt/
     2.最权威、详细的莫过于birt 官方文档 
     3.难得的比较全面的 BIRT 中文指南
     4.Flash Demo

2.部署BIRT2.1

2.1. 拷贝文件

 将/plugins, /configuration两个目录复制到webapp 根目录, 将lib复制到webapp/WEB-INF/lib

2.2. 瘦身

     Birt实在太过庞大,如果将以上三个目录全拷的话几十M.因此,可以参考SS里对/lib/birt 和 webapp/plugins目录反复试验后的精简。
     另外,/lib和/plugins有好多jar是重复的,只要在编译时把jar 从一个目录copy过去就行。又要注意两个目录里相同的jar的命名并不相同,而/plugins里面的文件名很严格,可参考build.xml里的这段复制命令

        <copy file="lib/birt/com.ibm.icu-3.4.4.1.jar" tofile="${web.dir}/plugins/com.ibm.icu_3.4.4.1.jar"/>
        <copy file="lib/birt/js-2.1.jar" tofile="${web.dir}/plugins/org.mozilla.rhino/lib/js.jar"/>
        <copy file="lib/birt/chartengineapi-2.1.jar" tofile="${web.dir}/plugins/org.eclipse.birt.chart.engine_2.1.0.N20060628-1351.jar"/>
        <copy todir="${web.dir}/plugins">
            <fileset dir="lib/birt">
                <include name="org.eclipse.emf.*"/>
              </fileset>
        </copy>

3.将spring与birt集成在一起

3.1 why not 说明

      3.1.1 为什么没有使用 birt report viewer

BIRT Report Viewer 貌似做得很周到,提供如浏览,打印,export to CSV ,过滤参数的传入等一系列的快速操作.

然而细心思考过,这个viewer还是存在不少问题:

如不适用的报表传入参数方式(无输入验证,无日期控件);代码复杂,可扩展性差......

发现不少功能形同虚设,所以决心抛弃.

     3.1.2 为什么不在.rptdesign里写sql

往往实际项目的业务总是复杂的,不希望将复杂的逻辑通过几个简单的参数传入拼凑sql来实现,再说这样调试sql也是一件麻烦的事情,也不利于SQL管理

所以我们提倡 将查询的商业逻辑放回java Manager类,然后designer负责设计数据如何排列。这样子更适和实际项目.

3.2 自己实现的BirtReportsView的原理

    实现Spring MVC的View,关键是重载它的protected void renderMergedOutputModel(Map model, HttpServletRequest request, HttpServletResponse response) 函数

   3.2.1 创建 EngineConfig 与 ReportEngine  实例
  public class BirtReportsView extends AbstractUrlBasedView {


  
   private String engineHome;
   private ReportEngine engine;
    
   public BirtReportsView() {
        engineHome = System.getProperty("bookstore.root");  //engine home
        EngineConfig birtConfig = new EngineConfig();
        birtConfig.setEngineHome(engineHome);
        engine = new ReportEngine(birtConfig); 
    }




    }
    3.2.2  设定报表文件
    public void openReportDesign(String filePath) throws IOException, EngineException {
        File reportFilte = new File(engineHome + "/" + filePath);
        IReportRunnable design = engine.openReportDesign(reportFilte.getAbsolutePath());
        task = engine.createRunAndRenderTask(design);
       }
     3.2.3  配置 htmlrendercontext
 private String scriptableJOName = "dsFactory"; //dsFactory 自由定义,主要在rptdesign中调用
private String imageDirectory = "/report/images";
private String baseImageUrl = "images";

 
 private void run(OutputStream outputStream) throws EngineException {

        HTMLRenderContext renderContext =  new         HTMLRenderContext();   


        //chart 生成图片目录
        renderContext.setImageDirectory(this.engineHome + "/" + imageDirectory);
    

        //web页面浏览 base url
        renderContext.setBaseImageURL(baseImageUrl);
        HashMap contextMap = new HashMap();
        contextMap.put(EngineConstants.APPCONTEXT_HTML_RENDER_CONTEXT, renderContext);

  
        task.setAppContext(contextMap);




        BirtDataSourceObject birtDataSourceObject = new BirtDataSourceObject();
        HTMLRenderOption options = new HTMLRenderOption();
        birtDataSourceObject.setResultList(resultList);
        options.setOutputStream(outputStream);
        task.setRenderOption(options);
 
        //增加api级别的java对象,以方便报表中调用获取报表数据
        task.addScriptableJavaObject (scriptableJOName, birtDataSourceObject);
        task.run();
 }

相关文章:
1.BIRT and POJOs as datasources example
2.详细的 Report Engine API 请见[官方 ]

3.3 Birt View的使用

见SaleReprontController.

public ModelAndView view(HttpServletRequest request, HttpServletResponse response) throws Exception {
        String status = request.getParameter("status");
        String beginDate = request.getParameter("beginDate");
        String endDate = request.getParameter("endDate");
        List bookList = saleReportManager.findBooksByReportParam(status,
                DateUtil.parse(beginDate, "yyyy-M-d"), DateUtil.parse(endDate, "yyyy-M-d"));
       BirtReportView view = new BirtReportView();
        view.openReportDesign("/report/sale_report.rptdesign");
        view.putModel(bookList);
        return new ModelAndView(view);
    }
分享到:
评论
发表评论

文章已被作者锁定,不允许评论。

相关推荐

    birt报表详细中文文档

    这个“birt报表详细中文文档”提供了全面的指南,帮助用户理解和利用BIRT的各项功能。 BIRT的核心特性包括: 1. **设计环境**:BIRT Report Designer是基于Eclipse IDE的集成开发环境,允许用户通过拖放方式创建...

    转:Birt接收JSP传递的参数值

    1. **定义BIRT报表参数**:在BIRT报表设计中,我们需要先定义所需的参数。这些参数可以在BIRT Report Designer的“参数”面板中创建,设置参数的名称、类型和默认值。 2. **JSP页面创建**:在JSP页面上,需要创建...

    Birt报表开发手册

    Birt报表开发手册 本手册旨在帮助开发者快速了解和掌握Birt报表开发技术,适用于Birt 2.1.3版本。下面是手册中所涉及的知识点: 一、Birt介绍 Birt(Business Intelligence and Reporting Tools)是一款开源的...

    birt报表工具

    ### BIRT 报表工具详解 #### 一、BIRT 报表工具简介 BIRT (Business Intelligence and Reporting Tools) 是一款开源的报表系统,它为开发者提供了强大的数据展现功能。BIRT 作为 Eclipse 项目的一部分,充分利用了...

    BIRT报表开发指南(中文版)

    **BIRT报表开发指南中文版** BIRT(Business Intelligence and Reporting Tools)是Eclipse基金会下的一款开源报表系统,主要用于生成动态、交互式的Web报表。它提供了丰富的图表、表格和自定义组件,支持多种数据...

    birt报表资料_珍藏.rar

    【BIRT报表技术详解】 BIRT(Business Intelligence and Reporting Tools)是Eclipse基金会下的一个开源项目,专门用于生成丰富的报表和数据分析。它提供了一个全面的报表系统,支持从各种数据源提取数据,创建复杂...

    Birt报表工具设计指南

    **Birt报表工具设计指南** Birt(Business Intelligence and Reporting Tools)是一款开源的企业级报表工具,主要用于生成高质量的报表和数据分析。它集成了Eclipse IDE,使得开发人员可以在熟悉的环境中设计复杂的...

    Birt报表操作手册

    Birt报表操作手册 Birt报表操作手册是一个功能强大的报表设计和生成工具,提供了灵活的报表设计和生成功能。下面是对Birt报表操作手册中的知识点的详细解释: 报表设计 在Birt报表操作手册中,报表设计是指创建...

    报表工具Birt开发文档

    **Birt报表工具开发文档** Birt(Business Intelligence and Reporting Tools)是一款开源的报表系统,由Eclipse基金会维护,主要用于生成动态的、交互式的商业报表。这个开发文档旨在为初学者提供一个全面的Birt...

    birt 报表教程 中文

    ### BIRT报表设计基础知识点详解 #### 一、BIRT报表设计概览 **BIRT (Business Intelligence and Reporting Tools)** 是一款开源的商务智能和报表工具,主要用于开发和部署复杂的数据报表。它提供了丰富的功能来...

    BIRT报表应用预研报告

    **BIRT报表应用预研报告** BIRT(Business Intelligence and Reporting Tools)是Eclipse基金会下的一款开源报表系统,专门用于生成复杂的企业级报表。它集成了数据可视化、数据分析和报告生成的功能,支持多种数据...

    birt报表,很好的java报表插件

    标题“birt报表,很好的java报表插件”所体现的关键知识点包括: 1. **BIRT的性质**:BIRT是一个基于Java的报表系统,它以插件的形式嵌入到Eclipse IDE中,使得开发人员能够方便地在Java应用中添加报表功能。 2. **...

    birt报表的官方API

    在开发BIRT报表时,理解和掌握其官方API至关重要,因为这将直接影响到报表的设计、数据处理以及功能实现。 首先,我们要理解BIRT API的核心组成部分: 1. **Report Designer API**:这是BIRT的图形化报告设计界面...

    birt报表的动态sql

    动态SQL是BIRT报表设计中的一个重要概念,它允许开发者根据用户输入或业务需求动态地构造SQL查询语句,极大地提高了报表的灵活性和实用性。 在BIRT中,动态SQL主要体现在以下几个方面: 1. **参数化查询**:BIRT...

    Birt报表开发教程

    **Birt报表开发教程** Birt(Business Intelligence and Reporting Tools)是Eclipse基金会下的一个开源项目,主要用于开发数据可视化和商业智能报告。本教程将深入介绍Birt报表开发的各个方面,帮助你掌握这一强大...

    birt报表开发总结

    7. **交互性**:BIRT报表支持交互式功能,如钻取、下钻、切片、切块等,使用户能够深入探索数据。此外,报表中可以嵌入链接,跳转到其他页面或应用。 8. **图表功能**:BIRT提供了多种图表类型,如柱状图、饼图、...

    birt报表开发 (二)、birt报表初体验-第一个报表

    在本篇博文中,我们将深入探讨"Birt报表开发"的第二部分——"Birt报表初体验-第一个报表"。Birt(Business Intelligence and Reporting Tools)是开源的企业级报告解决方案,它提供了一种强大的方式来创建、设计和...

    birt报表设计资料

    **Birt报表设计资料** Birt(Business Intelligence and Reporting Tools)是Eclipse基金会下的一个开源项目,主要用于开发数据可视化和商业智能报告。这份资料“Birt报表设计资料”显然是为初学者提供的一份宝贵的...

    maximo系统birt报表的eclipese开发配置及导入系统

    本篇文章将详细介绍如何配置Eclipse开发环境,以便在Maximo系统中开发和导入BIRT报表。 首先,你需要确认Maximo系统的版本,因为不同的Maximo版本可能需要匹配特定版本的BIRT报表工具。例如,Maximo 7.5对应的是...

Global site tag (gtag.js) - Google Analytics