靈魂-放水

          為學(xué)日益,為道日損。

          BlogJava 首頁 新隨筆 聯(lián)系 聚合 管理
            296 Posts :: 10 Stories :: 274 Comments :: 0 Trackbacks

          1 、概述

          如何實(shí)現(xiàn) 發(fā)Web報(bào)表有很多的選擇,自定義CSS+HTML或是XSLT+XML或是其他控件,特別是支持圖表的控件,比如:jfreechart。本文作為Web報(bào)表的一種實(shí)現(xiàn)方式,建議你使用Jasperreport作為報(bào)表控件,第一、二部分已經(jīng)對(duì)制作報(bào)表和開發(fā)胖客戶端報(bào)表應(yīng)用做了介紹,其實(shí)有很多的文章可以參考實(shí)現(xiàn)第三部分的內(nèi)容,不止是我寫的這篇文章。

          2 、數(shù)據(jù)連接建立

          參考 http://blog.csdn.net/jemlee2002/archive/2004/09/28/JJEM.aspx, 這里有詳細(xì)的介紹數(shù)據(jù)庫的連接過程。

          3 、拷貝必要的 jar 文件到 Web 應(yīng)用的 WEB-INF\lib 目錄

          每個(gè)Web應(yīng)用都會(huì)有WEB-INF目錄,但是lib是不一定有的,如果沒有就創(chuàng)建它,本文需要的jar庫文件有3個(gè):

          jasperreports-0.5.3.jar :jasperreports執(zhí)行時(shí)需要的API

          iTextAsian.jar :亞洲字符集支持

          itext-1.02b.jar :其他字符集支持

          如果你的報(bào)表全英文或是不需要支持亞洲字符集,那么iTextAsian.jar、可以不要。

          4 、創(chuàng)建 repotrs 目錄并導(dǎo)入 .jasper 文件

          Web應(yīng)用中根目錄下創(chuàng)建repotrs目錄,其實(shí)這是一種建議,沒有必要完全按照這樣做,你可以根據(jù)你的業(yè)務(wù)需要?jiǎng)?chuàng)建N個(gè)目錄或是層次目錄。

          .jasper文件拷貝到repotrs目錄下,比如例子中的BusinessRpt.jasper文件。

          5 、例子程序

          Test.jsp文件的內(nèi)容:

          <%@ page session="false" %>

          <%@ page import="dori.jasper.engine.*" %>

          <%@ page import="javax.naming.*"%>

          <%@ page import="java.sql.*"%>

          <%@ page import="javax.sql.*"%>

          <%@ page import="java.util.*" %>

          <%@ page import="java.io.*" %>

          <html>

          <head>

          <meta http-equiv="Content-Type" content="text/html; charset=gb2312">

          <title></title>

          <%??

          ?? DataSource ds = null;

          ?? try{

          ???? ?? InitialContext ctx=new InitialContext();

          ???? ?? ds=(DataSource)ctx.lookup("java:comp/env/jdbc/mysql");

          ???? ?? Connection conn = ds.getConnection();

          ???? ?? //裝載jasper文件

          ???? ?? File business_rpt = new File(application.getRealPath("/reports/BusinessRpt.jasper"));

          ???? ?? //配置參數(shù),可以參考《第二部分:使用Jasperreport作為報(bào)表控件開發(fā)胖客戶端報(bào)表應(yīng)用》

          ????? ? ?// http://blog.csdn.net/jemlee2002/archive/2004/10/08/JJem3.aspx

          ???? ?? //ProjectName就是iReport的變量$P{ProjectName}的名稱,

          ???? ?? //參考第一部分的5.6添加參數(shù)和使用參數(shù)

          ???? ?? //proname就是從界面上獲取的值。

          Map parameters = new HashMap();

          ???? ?? parameters.put("ProjectName ", proname);

          ??????? // JasperRunManager是一個(gè)輸出控制管理類,下文會(huì)提及部分內(nèi)容

          ???? ?? JasperRunManager.runReportToHtmlFile(business_rpt.getPath(),parameters,conn);

          ?????? //如果創(chuàng)建報(bào)表成功,則轉(zhuǎn)向該報(bào)表,其實(shí)可以把報(bào)表套在框架內(nèi),這樣實(shí)現(xiàn)比較有意義的報(bào)表格式。

          ???? ?? response.sendRedirect("/reports/BusinessRpt.html");

          ?? }catch(Exception ex){

          ?????? out.print("出現(xiàn)例外,信息是:"+ex.getMessage());

          ?????? ex.printStackTrace();

          ?? }

          %>

          </head>

          <body>

          </body>

          </html>

          6 、關(guān)于 JasperRunManager

          JasperRunManager有很多的靜態(tài)方法,控制輸出的格式,比如輸出格式是pdf或是html等,建議瀏覽JasperRunManager的一些方法,這樣對(duì)開發(fā)報(bào)表輸出有幫助。

          7 、輸出內(nèi)容

          例子中輸出格式是以HTML文件格式,所以web服務(wù)器可以直接解釋并顯示,效果不錯(cuò)。

          posted on 2006-12-17 10:23 放水老倌 閱讀(505) 評(píng)論(0)  編輯  收藏 所屬分類: 打印報(bào)表
          主站蜘蛛池模板: 华池县| 揭西县| 绥滨县| 北海市| 武宁县| 洪洞县| 仙居县| 南华县| 陇西县| 马边| 伽师县| 谢通门县| 惠水县| 民权县| 遂昌县| 盱眙县| 元朗区| 凤冈县| 灌南县| 南皮县| 都江堰市| 穆棱市| 大港区| 榕江县| 饶阳县| 新乡县| 德令哈市| 益阳市| 商洛市| 呼和浩特市| 金塔县| 清水河县| 陆川县| 江北区| 余庆县| 江安县| 德钦县| 内江市| 洪湖市| 宿迁市| 固安县|