`
cyfgod
  • 浏览: 65304 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

[原创]BIRT Viewer 2.2 参数设置详解

    博客分类:
  • BIRT
阅读更多

BIRT Viewer 2.2 参数设置详解

作者:会飞的球球
2007.08.24

BIRT作为一款功能强大的开源报表工具,其版本的升级更新速度也非常快,从1.0到2.0,一直到最新的2.2.1版本,无论从功能上还是性能上都得到了极大的提高和扩充。BIRT也提供了一个标准的J2EE实现组件,可以发布到支持J2EE应用的web server服务器上,可以对生成的报表进行预览等操作。在大家使用BIRT Viewer的时候,可能会对它日益纷繁的参数设置如云里雾里,在网上论坛里也有很多人碰到这样哪样的问题,同时官方的文档也不细致不全。所以我就对这些参数进行了一个简单系统的总结,希望能对大家的BIRT开发有所帮助。这些参数以2.2.1版本为准,请大家特别注意。

1. Servlet模式说明

  查看BIRT Viewer自带的web.xml文件,可以看到有以下几个pattern:

  frameset ---- 采用Ajax框架,可以显示工具条,导航条和TOC面板,实现复杂的操作,如分页处理,导出数据,导出报表,打印等等。该模式下会自动生成report document文件(预览report design文件)到特定的目录(用户可以用参数指定,也可以定义在web.xml里)。采用Ajax,速度较慢。

  run ---- 也采用Ajax框架,但不实现frameset的复杂功能,不会生成临时的report document文件(预览report design文件),也不支持分页,这个主要是应用在BIRT Designer里的preview tab里,可以支持cancel操作,其它不怎么常用。采用Ajax,速度较慢。

  preview --- 没有用到Ajax框架,直接调用底层Engine API对报表进行render,把生成的报表内容直接输出到浏览器。这种模式和run模式调用的是相同的Engine API,唯一区别在于run采用Ajax获取报表内容,而preview直接输出到浏览器。如果要支持分页,用户需要在URL上定义__page和__pagerange参数,这两个参数也会在后面详细说明。需要特别说明的是,在这几种预览模式中,preview的速度是最快的。

  document --- 该模式主要是为了从report design文件生成report document文件。用户可以在URL上提定document文件生成存放的路径(存放在server端),如果未指定,会直接生成rptdocument发送到客户端浏览器,用户可以下载到客户端。

  output --- 该模式类似于frameset,会自动生成report document文件(预览report design文件),区别在于output不采用Ajax,而是将生成的报表内容直接输出到浏览器。

  parameter --- 该模式主要用于生成一个参数对话框,一般用户不常用,用户可以直接通过提供的JSP Tag--parameterPage去实现参数对话框,不需要直接调用。

  download --- 用于导出报表数据为CSV格式,当你使用frameset工具条里的导出数据功能时,会用到这个模式。

2. web.xml里的参数设置
web.xml文件里有许多参数,用户应该根据自已的需求出发对这些参数有一个深入的了解。下面我会对这些参数一一做以说明。

[BIRT_VIEWER_LOCALE]
设置默认的Locale信息,暂时没有太大意义。因为Locale的信息,首先以URL上定义的__locale为准,如果没有定义,会找到当前浏览器的Locale信息,最后才会用到这里定义的信息。

[BIRT_VIEWER_WORKING_FOLDER]
设置BIRT Viewer的工作目录。用户可以把report design或是report document文件存放在这个目录下,这样就可以在URL上采用相对路径去预览这些报表文件了。默认是当前根目录。
当前支持三种形式:
相对路径 --- 这个相对当前的WEB应用的context root.
绝对路径
JAVA系统变量 --- 可以在启动服务器时,定义JVM的系统变量,如java –Dmyworkingfolder=D:/reports。这样就可以在web.xml中用${myworkingfolder}进行引用了。

[BIRT_VIEWER_DOCUMENT_FOLDER]
设置生成的document文件的存放路径。默认是documents目录。路径设置同上。

[WORKING_FOLDER_ACCESS_ONLY]
简单的报表访问限制控制实现,如果设为true,哪就只能预览存放在工作目录下的报表文件。默认值是false。

[BIRT_VIEWER_IMAGE_DIR]
设置生成的临时图片的存放路径。默认是report/images目录。路径设置同工作目录设置。

[BIRT_VIEWER_LOG_DIR]
设置生成的日志文件存放路径。默认是logs目录。路径设置同工作目录设置。

[BIRT_VIEWER_LOG_LEVEL]
设置日志的level,可选的值有:ALL|SEVERE|WARNING|INFO|CONFIG|FINE|FINER|FINEST|OFF。级别由高到低。

[BIRT_VIEWER_SCRIPTLIB_DIR]
设置用户script lib文件的存放目录( 在报表中用到的Java Event Handler Class )。默认值是scriptlib。路径设置同工作目录设置。

[BIRT_RESOURCE_PATH]
设置用户资源存放路径,这些资源包括library文件,image文件等。默认是当前根目录。路径设置同工作目录设置。

[BIRT_VIEWER_MAX_ROWS]
设置获取dataset的最大记录数。主要应用于设计报表的时候,预览报表如果记录数太多,会花费很多的时间,也可能会引起out of memory问题。默认是不限制。

[BIRT_VIEWER_MAX_CUBE_LEVELS]
设置CUBE查询的最大级数。和前面的参数作用类似。默认是不限制。

[BIRT_VIEWER_CUBE_MEMORY_SIZE]
设置在生成CUBE时,可以写在memory中的最大值,单位是MB。可以提高效率,写在内存会比直接写在硬盘快很多。但同时也要注意内存占用的问题。

[BIRT_OVERWRITE_DOCUMENT]
该参数主要用于frameset/output模式,它们会生成临时的document文件上。如果设为true,则每次刷新页面时,都会重新去生成document文件,如果为false,则不会重新生成,只会用原来的document文件去生成报表内容。

[BIRT_VIEWER_CONFIG_FILE]
定义properties文件的路径,不可以修改。

[BIRT_VIEWER_PRINT_SERVERSIDE]
在frameset工具条上,提供有后台服务器打印的功能,该参数可以设置是打开还是关闭后台打印的功能。默认是打开。可选值为: ON 和 OFF。

[HTML_ENABLE_AGENTSTYLE_ENGINE]
这个参数是会传递给Engine的,主要用于一些CSS的兼容性方面的问题。默认值是true。

3. viewer.properties参数设置
viewer.properties文件主要是定义一些扩展的参数。

# configurable variable for JSP base href. Please uncomment the below line.
#base_url=http://127.0.0.1:8080
该设置主要应用于代理服务器的情况下,在使用代理服务器后,从request里获取的URI并非真正的URI,需要在这里定义。

# [EXTENSION SETTING]
viewer.extension.html=html
viewer.extension.pdf=pdf
viewer.extension.postscript=ps
viewer.extension.doc=doc
viewer.extension.xls=xls
viewer.extension.ppt=ppt
定义输出的报表文件的后缀名,和format相关联。

# [OUTPUT FORMAT LABEL NAME]
viewer.label.html=HTML
viewer.label.pdf=PDF
viewer.label.postscript=PostScript
viewer.label.doc=Word
viewer.label.xls=Excel
viewer.label.ppt=PowerPoint
定义导出报表对话框里的报表格式列表,和format相关联,这样名字会更有意义。

# [CSV SEPARATOR]
viewer.sep.0=,
viewer.sep.1=;
viewer.sep.2=:
viewer.sep.3=|
viewer.sep.4=\t
支持多种CSV分隔符,用户也可以增加新的分隔符(只支持char,而不是string)。但同时需要修改JSP文件和Messages.properties文件。

# [LOGGERS]
# "logger."+class=level
# if no level is specified or the text "DEFAULT",
# then the default level from the web.xml will be used
logger.org.eclipse.datatools.connectivity.oda=DEFAULT
logger.org.eclipse.datatools.enablement.oda=DEFAULT
当前的日志都是通过Engine输出的,如果需要其它组件的日志输出,可以在这里定义。注意格式必须为logger.org……。而且该组件必须实现了java的logger。
可以单独为该组件设置日志级别,如果设为DEFAULT,就会使用web.xml里的设置。

4. URL参数
下面是一些主要用到的URL参数。

“__report”
定义要预览的rptdesign文件路径,支持相对路径和绝对路径,相对路径是相对于web.xml中定义的工作目录。

“__document”
定义要预览的rptdocument文件路径,同样支持相对和绝对路径。相对路径是相对于web.xml中定义的工作目录。在同时定义了__report和__document参数时,以__document为优先,如未找到相应的document文件,才会从design文件生成document文件(frameset/output)或是直接去render这个design文件(preview/run)。

“__title”
定义报表显示的标题。

“__showtitle”
是否显示frameset模式下上方的标题部分。true | false

“__toolbar”
是否显示frameset模式下的工具条。true | false

“__navigationbar”
是否显示frameset模式下的导航条。true | false

“__parameterpage”
是否强制弹出或不弹出报表参数对话框。true | false

“__format”
输出报表的格式,默认为html。现在支持:pdf | doc | xls | postscript | ppt

“__locale”
设置Locale信息,如 __locale=zh_CN, 注意必须是国家加语言。

“__svg”
设置chart输出是否以SVG格式输出。true | false
frameset和run模式下,会采用javascript判断客户端浏览器是否支持svg,但并非对所有浏览器有效。

“__bookmark”
设置页面要定位的书签名字。

“__istoc”
指定定位的书签是不是一个TOC名字。如为true,就会根据__bookmark参数值去获取一个真正的书签名,从而实现正常的跳转。这个主要用于定位到一个TOC上。

“__rtl”
指定HTML页面输出是否需要right to left。支持不同国家的阅读习惯,如阿拉伯国家是从右到左的。

“__page”
指定要输出的报表页数,这个依赖于报表的分页设计(page break)。

“__pagerange”
指定要输出的报表页数范围。如1,3,5-9。

“__resourceFolder”
定义资源目录路径。同web.xml中的BIRT_RESOURCE_PATH设置。

“__asattachment”
是否以附件方式下载报表,如生成PDF或是其它格式里。默认是inline。

“__masterpage”
是否要显示master page。true | false

“__designer”
该参数主要是应用在BIRT Designer环境下,如会读取cache的报表参数等等,一般不用。true | false

“__overwrite”
该参数同web.xml定义的参数,不过web.xml里是全局设置,在URL上通过参数可以定义本次操作的设置。

“__imageID”
内部参数,用于image的引用,一般不用。

“__maxrows”
设置Dataset查询的最大记录数,要注意这个设置是全局的,会影响后面所有的请求。主要用于BIRT Designer下,提高报表设计效率。同web.xml中的BIRT_VIEWER_MAX_ROWS设置。

“__maxlevels”
设置查询获取Cube的最大级数。同上面的__maxrows,也主要用于BIRT Designer设计环境。
同web.xml中的BIRT_VIEWER_MAX_CUBE_LEVELS设置。

“__cubememsize”
同web.xml中的BIRT_VIEWER_CUBE_MEMORY_SIZE参数设置。

“__instanceid”
如果查看BIRT输出的HTML代码,你就可以看到一些HTML Element会有一个iid的属性(如table),这个就是instanceid。这个是Engine动态生成的,不可提前预知。所以你需要从HTML代码中得到这个值。该参数主要是为了获取reportlet(报表片断,如只输出报表中的一个Table或是一个Chart)。需要配合__isreportlet参数。

“__isreportlet”
指定当前输出是不是一个reportlet。true | false
特别说明:为了输出一个reportlet,BIRT现在提供两种方式。
1. 为要输出的对象(表格或是Chart)定义一个bookmark,然后可以用下面的URL输出reportlet.
http://localhost:8080/birt/frameset?__report=test.rptdesign&__bookmark=bk&__isreportlet=true

2. 采用instanceid,但这个值事先是无法预知的,需要预览一次后从HTML代码中得到。然后用下面的URL输出reportlet.
http://localhost:8080/birt/output?__report=test.rptdesign&__instanceid=iid&__isreportlet=true
还有就是要注意,reportlet只支持document文档。如果是预览design文档去输出reportlet,就必须要使用frameset/output(自动生成document文档)。

“__clean”
BIRT里临时生成的一些文件都是和session相关的,比如临时document文件,还有image文件。这些文件也可以通过session进行管理,这个参数就是指定是否需要在session timeout的时候清除这些临时文件。默认值是true。
true | false

“__dpi”
可以设置输出Chart的dpi数值。

“__fittopage”
暂时这个参数只对PDF和postscript格式报表有效,指定是否调整至适合页面。

“__pagebreakonly”
暂时这个参数只对PDF和postscript格式报表有效,指定是否只采用BIRT报表内定的分页设置。这个参数一般需要和__fittopage联合使用。

“__agentstyle”
同web.xml中的HTML_ENABLE_AGENTSTYLE_ENGINE参数设置。

========================== 后台Server端打印相关参数 ==========================
“__action”
定义执行的指令名称。当前只支持print指令,用于后台服务器打印。

“__printer”
后台打印机名称。

“__printer_copies”
对应打印机的打印份数参数。

“__printer_collate”
对应打印机的双面打印参数。

“__printer_duplex”
对应打印机的duplex参数。

“__printer_mode”
对应打印机的模式参数。是单色还是彩色。

“__printer_pagesize”
对应打印机的纸型参数。比如A4。
===============================================================================

========================== JSP Tag相关参数  ===================================
“__id”
viewer的ID号,这个参数一般不常用,主要用于JSP Tag中,如在一个页面插入两个BIRT Viewer,而且预览同一个报表文件,这时候因为在一个session下面,所以需要用不同的ID去生成单独的document文件。不至于都生成同一个document文件上,从而引发冲突。

“__pattern”
在JSP Tag中用于指定要提交的Servlet Pattern名字,如frameset/output/run/preview等。主要用于采用parameter模式生成parameter dialog对话框时。

“__target”
可以指定提交到的窗口名称。如_blank,_self等。

“__nocache”
指定是否会用到cache的报表参数值,这些cache的值一般保存在rptconfig文件里。在设计报表并预览的时候,可以保存输入的报表参数值。这个在runtime的时候不常用。
===============================================================================

========================== 报表参数相关 ===================================
“__isnull”
指定当前的报表参数为null值,后面是报表的参数名。

“__islocale”
指定当前的报表参数值是和Locale/Format相关的,必须用特定的Locale/Format转化参数值(从String转化为Object)。格式为__islocale=paramName。

“__isdisplay__”
指定报表参数的displayText值,格式为__isdisplay__paramName=displayText。可以在报表中引用displayText值,如params[“p1”].displayText。
在URL上传displayText时如下(报表参数名为p1):
&__isdisplay__p1=hello

“__islocale__”
指定该报表参数值是Locale/Format相关的,同时给定了参数值。格式为__islocale__paramName=paramValue。
===============================================================================

========================== Export Data参数 ===================================
“__exportEncoding”
该参数应用于导出数据为CSV中,可以指定导出的文件编码,如GBK或是GB2312等。

“__sep”
该参数应用于导出数据为CSV中,可以指定数据分隔符,如逗号,冒号等。

“__exportdatatype”
该参数应用于导出数据为CSV中,可以指定是否输出数据类型。true | false

“ResultSetName”
要导出数据的记录集名字。

“SelectedColumnNumber”
要导出的栏位数。

“SelectedColumn”
要导出的数据栏位名称。

具体可以查看BirtSimpleExportDataDialog.js文件。
===============================================================================

5. 其它参数设置
在BIRT Viewer里还有一个比较特殊的参数应用,就是用户可以自定义自已的servlet,然后传递对象到Application Context中,在报表中就可以从全局的Application Context去获取到这个对象。
这里相关的有两个内定的参数,AppContextKey和AppContextValue。下面是一个简单的示例。
 public void service( HttpServletRequest request,
   HttpServletResponse response ) throws ServletException,
   IOException, BirtException
 {
  String myKeyName = "mykey";
  List values = new ArrayList();
  values.add( "hello" );
  values.add( new Date() );
  request.setAttribute( "AppContextKey", myKeyName );
  request.setAttribute( "AppContextValue", values );
  RequestDispatcher rd = request.getRequestDispatcher( "/frameset" );
  rd.include( request, response );
 }

分享到:
评论
14 楼 dlut_zxf 2008-07-01  
目前birt没有接受Connection对象传入的接口,http://www.actuatechina.com上有对这个问题的一些解决方法,有兴趣可以去看看。
13 楼 cyfgod 2008-06-21  
而且BIRT会在2.3.1中支持这种Connection的应用。

请参看:
https://bugs.eclipse.org/bugs/show_bug.cgi?id=236565
12 楼 askyer 2008-06-20  
好文章 学习ing
11 楼 RogerTu 2008-06-17  
以上方法是通过变相修改BIRT自带的JDBC ODA Driver实现的,风险很大,例如:会不会引入其他问题,BIRT升级后还会工作吗等

事实上,BIRT即将支持通过接收用户的java.sql.Connection实例的方式创建数据源了,见:
https://bugs.eclipse.org/bugs/show_bug.cgi?id=236565

推荐BIRT官方中文论坛:http://www.actuatechina.com/index.php
10 楼 cyfgod 2008-06-10  
关于Connection的问题,你可以参考一下下面的文章。
http://birtworld.blogspot.com/2005/12/using-supplied-connection-with-birt.html
9 楼 cyfgod 2008-06-07  
rptdesign文件一般是已经设计完成的报表文件,它已经包含了Data Source和Data set,在BIRT里运行时,会调用相应驱动去获取数据进行展现。当然这个Data Source是可以有多种类型的,可以通过JDBC连接到数据库,也可以采用Flat File/XML做为数据源,BIRT还支持Web Service数据源。用户也可以进行扩展自已的数据源,如scripted data source,在BIRT里,很多东西都是可以自扩展的。
8 楼 咖啡舞者 2008-06-06  
刚刚转战到BIRT,想请问一下:
   webview中预览.rptdesign文件,怎么样使用当前系统的数据源连接?
   在用java application运算生成报表文件,在润乾报表和jasperReport报表中有API接受 Connection对象的传入,在BIRT中是否有类似的做法?

7 楼 cyfgod 2007-10-08  
现在只是支持Postscript格式的打印机,请确认你安装的打印机是否支持该格式。
6 楼 wushaoen 2007-09-25  
为什么我在print on server下显示不了server端的printer的?
就像http://www.karlshamn.se:8100/appl/frameset?__report=test.rptdesign&sample=my+parameter
打印在服务器端时显示不了打印机名称?如何设置?
5 楼 cnfree 2007-09-19  
Birt做得太大了,什么都想做,未来的版本也要支持Flash自动生成。以后估计有的忙得~
4 楼 cyfgod 2007-09-17  
是的,2.2.1build还没有release,但你可以在eclipse网站上下到最新的Nightly build。
3 楼 Leon 2007-09-14  
我说的官方是这里:
http://www.eclipse.org/birt/phoenix/
这么说Birt应该还有自己的主页.我google一下好了.
2 楼 Leon 2007-09-14  
对了,有一点不是很明白,2.2.1版本官方尚未放出,不知道你是从何得来的?
1 楼 Leon 2007-09-13  
前两年一直用MS的ReportingService做报表.
最近因为项目原因,引入了Birt,当初考虑使用Birt也是因为它和我们使用Eclipse作为开发环境有很大的关系.一直认为IDE之间应该尽可能的易整合.
忙活了2天,当然不能算之前的一些积累,终于把Birt比较完美的集成到了系统中..
在Eclipse社区就看了你的一些文章,很受用,故此回帖...等研究再深入一些,我也把资料整理一下发出来,作为经验总结.

相关推荐

    BirtViewer参数设置详解

    以下是对BIRT Viewer参数设置的详细解析,主要基于2.2.1版本。 1. Servlet模式: - **frameset**:使用Ajax框架,展示工具栏、导航栏和TOC面板,支持分页、数据导出、报表导出和打印等高级功能。此模式会在指定...

    BIRT_Viewer_2_2_参数设置详解.pdf

    《BIRT Viewer 2.2 参数设置详解》一文深入探讨了BIRT(Business Intelligence and Reporting Tools)这一强大开源报表工具的高级应用,特别是在BIRT Viewer 2.2版本中的参数配置与优化策略。BIRT作为一款成熟且功能...

    birt viewer源代码

    【Birt Viewer源代码详解】 BIRT(Business Intelligence and Reporting Tools)是由Eclipse基金会发起的开源项目,专门用于开发企业级报表系统。它提供了一套完整的报表设计、数据集成、呈现以及分发解决方案,...

    Birt 2.3.2.2学习资料

    ### Birt 2.3.2.2 学习资料详解 #### 一、简介 Birt(Business Intelligence and Reporting Tools)是一款开源的商务智能工具,由Eclipse基金会支持开发。它提供了一套完整的报告解决方案,包括数据访问、报告设计...

    Birt2.2M6每页小计及分页

    Birt2.2M6每页小计及分页 Birt 2.2M6 是一个功能强大的报表工具,它提供了强大的数据Reporting和分析功能。在这个版本中,我们可以使用 Group 来实现每页小计的功能,并且可以进行分页设置,以便更好地展示报表数据...

    Birt2.2M6的交叉表用法

    在数据分析和报告生成中,Birt 2.2M6 提供了强大的交叉表(CrossTab)功能,这是一种用于组织和展示数据的有效工具。交叉表允许用户以网格形式查看数据,便于比较不同分类下的数值,识别数据的趋势和模式。本文将...

    birt升级脚本(默认为2.2升级到2.5,脚本可自由配置)

    3.请修改birtUpgrade.properties中的old_driver_dir、backup_driver_dir连个属性,修改为对应的org.eclipse.birt.report.data.oda.jdbc目录名(默认为birt2.2 和2.5); 4.运行build20090715.xml下的upgrade任务; 5....

    Birt report viewer 汉化文件

    Birt report viewer 汉化文件

    Web报表开发技术-Eclipse Birt开发技术实例

    配置Birt Viewer的web.xml文件,设置数据源和报表路径。 5. **报表执行和展现**:在Web应用中,通过HTTP请求调用Birt Viewer的Servlet,传递参数以动态生成报表。Birt Viewer将根据请求生成报表HTML,用户可以通过...

    birt报表参数的使用

    Birt报表参数的使用 本文总结了Birt报表参数的使用机制,并结合实例详细地阐述了参数的各种使用方法,最后介绍了Birt报表的源代码级使用。 1. 参数机制 Birt报表参数具有变量的作用,为Birt报表的生成提供了一种...

    birt jsp tag

    BIRT从2.2开始(最好采用2.2M6及以后版本),提供JSP tag的支持。 现在主要提供了以下5个JSP Tag: 1. viewer --------- 对应 frameset/run 模式,基于Ajax 2. report ---------- 对应 preview模式 3. param --------...

    birt报表参数日期选择JS文件及操作步骤

    在BIRT(Business Intelligence and Reporting Tools)报表系统中,参数是一个关键特性,允许用户在运行时输入值,这些值可以影响报表的查询或过滤条件。本篇将详细讲解如何使用JavaScript来实现日期选择功能,以及...

    Birt 报表参数的使用

    ### Birt 报表参数的使用详解 Birt(Business Intelligence and Reporting Tools)是一款由Eclipse基金会维护的开源报表系统,被广泛应用于企业级报表设计与生成。Birt的灵活性和强大功能很大程度上得益于其参数...

    APACHE BIRT图表学习笔记

    ### Apache BIRT 图表学习笔记知识点详解 #### 一、Apache BIRT 概述 Apache BIRT(Business Intelligence and Reporting Tools)是一款开源的商务智能工具,由Eclipse基金会发起并维护。它为开发者提供了创建数据...

    如何实现基于Web2.0的BIRT Viewer应用

    NULL 博文链接:https://cyfgod.iteye.com/blog/277672

    birt整合到web项目中遇到的问题及解决

    要隐藏BIRT Viewer的标题栏和工具栏,可以在IFrame的src属性中添加相应参数,如`__showtitle=false`、`__toolbar=false`和`__navigationbar=false`。 7. **修改BIRT View Port风格** 修改BIRT视口样式通常涉及到...

    Birt Java 整合开发详解

    "Birt Java 整合开发详解" 本文将详细介绍如何构建一个 Birt 报表应用程序,从官方教材上翻译的,比较详细。 一、创建报表引擎 REPORT ENGINE 是 ReportEngine 类的一个实例,是任何报表应用程序的关键部分。首先...

    birt数据集参数与列绑定实现

    在BIRT(Business Intelligence and Reporting Tools)中,数据集参数与列绑定是构建复杂报告的关键技术。本主题将深入探讨如何实现数据集之间的参数传递以及列的绑定,以充分利用BIRT的功能来创建高效的报告。 ...

Global site tag (gtag.js) - Google Analytics