首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > Web前端 >

调整Struts2+JasperReport Web报表应用示例

2013-01-27 
整合Struts2+JasperReport Web报表应用示例整合Struts2JasperReport Web报表应用示例JasperReports作为一

整合Struts2+JasperReport Web报表应用示例

整合Struts2+JasperReport Web报表应用示例

JasperReports作为一种优秀且开源的报表引擎,不利用太可惜了。同时,借助开源的JasperReports模板设计利器iReports,可以可视化的设计报表模板。基于Web的报表在很多项目中都是需要的。而随着Struts2的流行,就应该研究一下在Struts2下如何利用JasperReports进行报表输出。本示例比较简单,采用的数据源即为JavaBean,而没有采用复杂的数据库,其实原理是一样的。只是传递给JasperReports的参数随着连接方式的变化而略加修改而已。

一 准备工作

所使用的类库及Jar包如下图所示:

调整Struts2+JasperReport Web报表应用示例
图1.使用的Jar包

开发环境:MyEclipse6.0+Eclipse3.3+JDK6.0+Tomcat6.0+Struts 2.0.11。当然,本该所提供的源代码下载中没有提供相关的lib,因为文件大太,如果需要,请留下email。.
    另外下载Jasperreport以及可视化模板iReport的网子http://jasperforge.org/

二 设计报表模板

本例中采用JavaBean作为数据源,用于显示People对象的一些基本属性,如所在序号、城市、姓名、地址,并对同一城市的人员进行汇总小结显示。

至于如何在iReports中设计模板文件,请在网上参考其它文档。这里不再详细解读,或有时间俺再另写文章来具体讲解如何在iReports中设计报表模板。WebRoot"jasper"jasper_template.jrxml代码如下:

调整Struts2+JasperReport Web报表应用示例<?xml version="1.0" encoding="UTF-8"  ?>
调整Struts2+JasperReport Web报表应用示例<!-- Created with iReport - A designer for JasperReports -->
调整Struts2+JasperReport Web报表应用示例<!DOCTYPE jasperReport PUBLIC "//JasperReports//DTD Report Design//EN" "http://jasperreports.sourceforge.net/dtds/jasperreport.dtd">
调整Struts2+JasperReport Web报表应用示例<jasperReport
调整Struts2+JasperReport Web报表应用示例         name="jasper_template"
调整Struts2+JasperReport Web报表应用示例         columnCount="1"
调整Struts2+JasperReport Web报表应用示例         printOrder="Vertical"
调整Struts2+JasperReport Web报表应用示例         orientation="Portrait"
调整Struts2+JasperReport Web报表应用示例         pageWidth="595"
调整Struts2+JasperReport Web报表应用示例         pageHeight="842"
调整Struts2+JasperReport Web报表应用示例         columnWidth="535"
调整Struts2+JasperReport Web报表应用示例         columnSpacing="0"
调整Struts2+JasperReport Web报表应用示例         leftMargin="30"
调整Struts2+JasperReport Web报表应用示例         rightMargin="30"
调整Struts2+JasperReport Web报表应用示例         topMargin="20"
调整Struts2+JasperReport Web报表应用示例         bottomMargin="20"
调整Struts2+JasperReport Web报表应用示例         whenNoDataType="NoPages"
调整Struts2+JasperReport Web报表应用示例         isTitleNewPage="false"
调整Struts2+JasperReport Web报表应用示例         isSummaryNewPage="false">
调整Struts2+JasperReport Web报表应用示例    <property name="ireport.scriptlethandling" value="0" />
调整Struts2+JasperReport Web报表应用示例    <property name="ireport.encoding" value="UTF-8" />
调整Struts2+JasperReport Web报表应用示例    <import value="java.util.*" />
调整Struts2+JasperReport Web报表应用示例    <import value="net.sf.jasperreports.engine.*" />
调整Struts2+JasperReport Web报表应用示例    <import value="net.sf.jasperreports.engine.data.*" />
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例    <parameter name="rptMan" isForPrompting="false" class="java.lang.String">
调整Struts2+JasperReport Web报表应用示例        <defaultValueExpression ><![CDATA["sterning"]]></defaultValueExpression>
调整Struts2+JasperReport Web报表应用示例    </parameter>
调整Struts2+JasperReport Web报表应用示例    <parameter name="rptDate" isForPrompting="false" class="java.lang.String">
调整Struts2+JasperReport Web报表应用示例        <defaultValueExpression ><![CDATA["2008-01-12"]]></defaultValueExpression>
调整Struts2+JasperReport Web报表应用示例    </parameter>
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例    <field name="city" class="java.lang.String">
调整Struts2+JasperReport Web报表应用示例        <fieldDescription><![CDATA[city]]></fieldDescription>
调整Struts2+JasperReport Web报表应用示例    </field>
调整Struts2+JasperReport Web报表应用示例    <field name="street" class="java.lang.String">
调整Struts2+JasperReport Web报表应用示例        <fieldDescription><![CDATA[street]]></fieldDescription>
调整Struts2+JasperReport Web报表应用示例    </field>
调整Struts2+JasperReport Web报表应用示例    <field name="id" class="java.lang.Integer">
调整Struts2+JasperReport Web报表应用示例        <fieldDescription><![CDATA[id]]></fieldDescription>
调整Struts2+JasperReport Web报表应用示例    </field>
调整Struts2+JasperReport Web报表应用示例    <field name="name" class="java.lang.String">
调整Struts2+JasperReport Web报表应用示例        <fieldDescription><![CDATA[name]]></fieldDescription>
调整Struts2+JasperReport Web报表应用示例    </field>
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例    <variable name="CityNumber" class="java.lang.Integer" resetType="Group" resetGroup="CityGroup" calculation="Sum">
调整Struts2+JasperReport Web报表应用示例        <initialValueExpression><![CDATA[($V{CityNumber} != null)?(new Integer($V{CityNumber}.intValue() + 1)):(new Integer(1))]]></initialValueExpression>
调整Struts2+JasperReport Web报表应用示例    </variable>
调整Struts2+JasperReport Web报表应用示例    <variable name="AllCity" class="java.lang.Integer" resetType="Report" calculation="Sum">
调整Struts2+JasperReport Web报表应用示例        <initialValueExpression><![CDATA[($V{AllCity} != null)?(new Integer($V{AllCity}.intValue() + 1)):(new Integer(1))]]></initialValueExpression>
调整Struts2+JasperReport Web报表应用示例    </variable>
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例        <group  name="CityGroup" >
调整Struts2+JasperReport Web报表应用示例            <groupExpression><![CDATA[$F{city}]]></groupExpression>
调整Struts2+JasperReport Web报表应用示例            <groupHeader>
调整Struts2+JasperReport Web报表应用示例            <band height="0"  isSplitAllowed="true" >
调整Struts2+JasperReport Web报表应用示例            </band>
调整Struts2+JasperReport Web报表应用示例            </groupHeader>
调整Struts2+JasperReport Web报表应用示例            <groupFooter>
调整Struts2+JasperReport Web报表应用示例            <band height="37"  isSplitAllowed="true" >
调整Struts2+JasperReport Web报表应用示例                <staticText>
调整Struts2+JasperReport Web报表应用示例                    <reportElement
调整Struts2+JasperReport Web报表应用示例                        x="98"
调整Struts2+JasperReport Web报表应用示例                        y="5"
调整Struts2+JasperReport Web报表应用示例                        width="51"
调整Struts2+JasperReport Web报表应用示例                        height="25"
调整Struts2+JasperReport Web报表应用示例                        key="staticText-8"/>
调整Struts2+JasperReport Web报表应用示例                    <box topBorder="None" topBorderColor="#000000" leftBorder="None" leftBorderColor="#000000" rightBorder="None" rightBorderColor="#000000" bottomBorder="None" bottomBorderColor="#000000"/>
调整Struts2+JasperReport Web报表应用示例                    <textElement>
调整Struts2+JasperReport Web报表应用示例                        <font fontName="瀹嬩綋" pdfFontName="STSong-Light" size="14" isPdfEmbedded ="true" pdfEncoding ="UniGB-UCS2-H"/>
调整Struts2+JasperReport Web报表应用示例                    </textElement>
调整Struts2+JasperReport Web报表应用示例                <text><![CDATA[灏忚锛歖]></text>
调整Struts2+JasperReport Web报表应用示例                </staticText>
调整Struts2+JasperReport Web报表应用示例                <textField isStretchWithOverflow="false" isBlankWhenNull="false" evaluationTime="Now" hyperlinkType="None"  hyperlinkTarget="Self" >
调整Struts2+JasperReport Web报表应用示例                    <reportElement
调整Struts2+JasperReport Web报表应用示例                        x="149"
调整Struts2+JasperReport Web报表应用示例                        y="5"
调整Struts2+JasperReport Web报表应用示例                        width="34"
调整Struts2+JasperReport Web报表应用示例                        height="25"
调整Struts2+JasperReport Web报表应用示例                        key="textField-7"/>
调整Struts2+JasperReport Web报表应用示例                    <box topBorder="None" topBorderColor="#000000" leftBorder="None" leftBorderColor="#000000" rightBorder="None" rightBorderColor="#000000" bottomBorder="None" bottomBorderColor="#000000"/>
调整Struts2+JasperReport Web报表应用示例                    <textElement>
调整Struts2+JasperReport Web报表应用示例                        <font fontName="瀹嬩綋" pdfFontName="STSong-Light" size="14" isPdfEmbedded ="true" pdfEncoding ="UniGB-UCS2-H"/>
调整Struts2+JasperReport Web报表应用示例                    </textElement>
调整Struts2+JasperReport Web报表应用示例                <textFieldExpression   class="java.lang.Integer"><![CDATA[$V{CityGroup_COUNT}]]></textFieldExpression>
调整Struts2+JasperReport Web报表应用示例                </textField>
调整Struts2+JasperReport Web报表应用示例                <line direction="TopDown">
调整Struts2+JasperReport Web报表应用示例                    <reportElement
调整Struts2+JasperReport Web报表应用示例                        x="-30"
调整Struts2+JasperReport Web报表应用示例                        y="36"
调整Struts2+JasperReport Web报表应用示例                        width="593"
调整Struts2+JasperReport Web报表应用示例                        height="0"
调整Struts2+JasperReport Web报表应用示例                        key="line-5"/>
调整Struts2+JasperReport Web报表应用示例                    <graphicElement stretchType="NoStretch"/>
调整Struts2+JasperReport Web报表应用示例                </line>
调整Struts2+JasperReport Web报表应用示例            </band>
调整Struts2+JasperReport Web报表应用示例            </groupFooter>
调整Struts2+JasperReport Web报表应用示例        </group>
调整Struts2+JasperReport Web报表应用示例        <background>
调整Struts2+JasperReport Web报表应用示例            <band height="0"  isSplitAllowed="true" >
调整Struts2+JasperReport Web报表应用示例            </band>
调整Struts2+JasperReport Web报表应用示例        </background>
调整Struts2+JasperReport Web报表应用示例        <title>
调整Struts2+JasperReport Web报表应用示例            <band height="62"  isSplitAllowed="true" >
调整Struts2+JasperReport Web报表应用示例                <staticText>
调整Struts2+JasperReport Web报表应用示例                    <reportElement
调整Struts2+JasperReport Web报表应用示例                        x="20"
调整Struts2+JasperReport Web报表应用示例                        y="0"
调整Struts2+JasperReport Web报表应用示例                        width="484"
调整Struts2+JasperReport Web报表应用示例                        height="57"
调整Struts2+JasperReport Web报表应用示例                        forecolor="#FF0033"
调整Struts2+JasperReport Web报表应用示例                        key="staticText-1"/>
调整Struts2+JasperReport Web报表应用示例                    <box topBorder="None" topBorderColor="#000000" leftBorder="None" leftBorderColor="#000000" rightBorder="None" rightBorderColor="#000000" bottomBorder="None" bottomBorderColor="#000000"/>
调整Struts2+JasperReport Web报表应用示例                    <textElement textAlignment="Center">
调整Struts2+JasperReport Web报表应用示例                        <font fontName="瀹嬩綋" pdfFontName="STSong-Light" size="36" isPdfEmbedded ="true" pdfEncoding ="UniGB-UCS2-H"/>
调整Struts2+JasperReport Web报表应用示例                    </textElement>
调整Struts2+JasperReport Web报表应用示例                <text><![CDATA[Struts2+JasperReports绀轰緥]]></text>
调整Struts2+JasperReport Web报表应用示例                </staticText>
调整Struts2+JasperReport Web报表应用示例                <line direction="TopDown">
调整Struts2+JasperReport Web报表应用示例                    <reportElement
调整Struts2+JasperReport Web报表应用示例                        x="-30"
调整Struts2+JasperReport Web报表应用示例                        y="61"
调整Struts2+JasperReport Web报表应用示例                        width="594"
调整Struts2+JasperReport Web报表应用示例                        height="0"
调整Struts2+JasperReport Web报表应用示例                        key="line-4"/>
调整Struts2+JasperReport Web报表应用示例                    <graphicElement stretchType="NoStretch"/>
调整Struts2+JasperReport Web报表应用示例                </line>
调整Struts2+JasperReport Web报表应用示例            </band>
调整Struts2+JasperReport Web报表应用示例        </title>
调整Struts2+JasperReport Web报表应用示例        <pageHeader>
调整Struts2+JasperReport Web报表应用示例            <band height="13"  isSplitAllowed="true" >
调整Struts2+JasperReport Web报表应用示例                <line direction="TopDown">
调整Struts2+JasperReport Web报表应用示例                    <reportElement
调整Struts2+JasperReport Web报表应用示例                        x="-29"
调整Struts2+JasperReport Web报表应用示例                        y="12"
调整Struts2+JasperReport Web报表应用示例                        width="592"
调整Struts2+JasperReport Web报表应用示例                        height="0"
调整Struts2+JasperReport Web报表应用示例                        key="line-3"/>
调整Struts2+JasperReport Web报表应用示例                    <graphicElement stretchType="NoStretch"/>
调整Struts2+JasperReport Web报表应用示例                </line>
调整Struts2+JasperReport Web报表应用示例            </band>
调整Struts2+JasperReport Web报表应用示例        </pageHeader>
调整Struts2+JasperReport Web报表应用示例        <columnHeader>
调整Struts2+JasperReport Web报表应用示例            <band height="45"  isSplitAllowed="true" >
调整Struts2+JasperReport Web报表应用示例                <staticText>
调整Struts2+JasperReport Web报表应用示例                    <reportElement
调整Struts2+JasperReport Web报表应用示例                        x="13"
调整Struts2+JasperReport Web报表应用示例                        y="5"
调整Struts2+JasperReport Web报表应用示例                        width="62"
调整Struts2+JasperReport Web报表应用示例                        height="33"
调整Struts2+JasperReport Web报表应用示例                        key="staticText-2"/>
调整Struts2+JasperReport Web报表应用示例                    <box topBorder="None" topBorderColor="#000000" leftBorder="None" leftBorderColor="#000000" rightBorder="None" rightBorderColor="#000000" bottomBorder="None" bottomBorderColor="#000000"/>
调整Struts2+JasperReport Web报表应用示例                    <textElement>
调整Struts2+JasperReport Web报表应用示例                        <font fontName="瀹嬩綋" pdfFontName="STSong-Light" size="24" isPdfEmbedded ="true" pdfEncoding ="UniGB-UCS2-H"/>
调整Struts2+JasperReport Web报表应用示例                    </textElement>
调整Struts2+JasperReport Web报表应用示例                <text><![CDATA[搴忓彿]]></text>
调整Struts2+JasperReport Web报表应用示例                </staticText>
调整Struts2+JasperReport Web报表应用示例                <staticText>
调整Struts2+JasperReport Web报表应用示例                    <reportElement
调整Struts2+JasperReport Web报表应用示例                        x="98"
调整Struts2+JasperReport Web报表应用示例                        y="5"
调整Struts2+JasperReport Web报表应用示例                        width="62"
调整Struts2+JasperReport Web报表应用示例                        height="33"
调整Struts2+JasperReport Web报表应用示例                        key="staticText-3"/>
调整Struts2+JasperReport Web报表应用示例                    <box topBorder="None" topBorderColor="#000000" leftBorder="None" leftBorderColor="#000000" rightBorder="None" rightBorderColor="#000000" bottomBorder="None" bottomBorderColor="#000000"/>
调整Struts2+JasperReport Web报表应用示例                    <textElement>
调整Struts2+JasperReport Web报表应用示例                        <font fontName="瀹嬩綋" pdfFontName="STSong-Light" size="24" isPdfEmbedded ="true" pdfEncoding ="UniGB-UCS2-H"/>
调整Struts2+JasperReport Web报表应用示例                    </textElement>
调整Struts2+JasperReport Web报表应用示例                <text><![CDATA[鍩庡競]]></text>
调整Struts2+JasperReport Web报表应用示例                </staticText>
调整Struts2+JasperReport Web报表应用示例                <staticText>
调整Struts2+JasperReport Web报表应用示例                    <reportElement
调整Struts2+JasperReport Web报表应用示例                        x="212"
调整Struts2+JasperReport Web报表应用示例                        y="5"
调整Struts2+JasperReport Web报表应用示例                        width="62"
调整Struts2+JasperReport Web报表应用示例                        height="33"
调整Struts2+JasperReport Web报表应用示例                        key="staticText-4"/>
调整Struts2+JasperReport Web报表应用示例                    <box topBorder="None" topBorderColor="#000000" leftBorder="None" leftBorderColor="#000000" rightBorder="None" rightBorderColor="#000000" bottomBorder="None" bottomBorderColor="#000000"/>
调整Struts2+JasperReport Web报表应用示例                    <textElement>
调整Struts2+JasperReport Web报表应用示例                        <font fontName="瀹嬩綋" pdfFontName="STSong-Light" size="24" isPdfEmbedded ="true" pdfEncoding ="UniGB-UCS2-H"/>
调整Struts2+JasperReport Web报表应用示例                    </textElement>
调整Struts2+JasperReport Web报表应用示例                <text><![CDATA[濮撳悕]]></text>
调整Struts2+JasperReport Web报表应用示例                </staticText>
调整Struts2+JasperReport Web报表应用示例                <staticText>
调整Struts2+JasperReport Web报表应用示例                    <reportElement
调整Struts2+JasperReport Web报表应用示例                        x="331"
调整Struts2+JasperReport Web报表应用示例                        y="5"
调整Struts2+JasperReport Web报表应用示例                        width="62"
调整Struts2+JasperReport Web报表应用示例                        height="33"
调整Struts2+JasperReport Web报表应用示例                        key="staticText-5"/>
调整Struts2+JasperReport Web报表应用示例                    <box topBorder="None" topBorderColor="#000000" leftBorder="None" leftBorderColor="#000000" rightBorder="None" rightBorderColor="#000000" bottomBorder="None" bottomBorderColor="#000000"/>
调整Struts2+JasperReport Web报表应用示例                    <textElement>
调整Struts2+JasperReport Web报表应用示例                        <font fontName="瀹嬩綋" pdfFontName="STSong-Light" size="24" isPdfEmbedded ="true" pdfEncoding ="UniGB-UCS2-H"/>
调整Struts2+JasperReport Web报表应用示例                    </textElement>
调整Struts2+JasperReport Web报表应用示例                <text><![CDATA[浣忓潃]]></text>
调整Struts2+JasperReport Web报表应用示例                </staticText>
调整Struts2+JasperReport Web报表应用示例                <line direction="TopDown">
调整Struts2+JasperReport Web报表应用示例                    <reportElement
调整Struts2+JasperReport Web报表应用示例                        x="-30"
调整Struts2+JasperReport Web报表应用示例                        y="43"
调整Struts2+JasperReport Web报表应用示例                        width="596"
调整Struts2+JasperReport Web报表应用示例                        height="0"
调整Struts2+JasperReport Web报表应用示例                        key="line-2"/>
调整Struts2+JasperReport Web报表应用示例                    <graphicElement stretchType="NoStretch"/>
调整Struts2+JasperReport Web报表应用示例                </line>
调整Struts2+JasperReport Web报表应用示例            </band>
调整Struts2+JasperReport Web报表应用示例        </columnHeader>
调整Struts2+JasperReport Web报表应用示例        <detail>
调整Struts2+JasperReport Web报表应用示例            <band height="43"  isSplitAllowed="true" >
调整Struts2+JasperReport Web报表应用示例                <textField isStretchWithOverflow="false" isBlankWhenNull="false" evaluationTime="Now" hyperlinkType="None"  hyperlinkTarget="Self" >
调整Struts2+JasperReport Web报表应用示例                    <reportElement
调整Struts2+JasperReport Web报表应用示例                        x="13"
调整Struts2+JasperReport Web报表应用示例                        y="7"
调整Struts2+JasperReport Web报表应用示例                        width="62"
调整Struts2+JasperReport Web报表应用示例                        height="30"
调整Struts2+JasperReport Web报表应用示例                        key="textField-1"/>
调整Struts2+JasperReport Web报表应用示例                    <box topBorder="None" topBorderColor="#000000" leftBorder="None" leftBorderColor="#000000" rightBorder="None" rightBorderColor="#000000" bottomBorder="None" bottomBorderColor="#000000"/>
调整Struts2+JasperReport Web报表应用示例                    <textElement>
调整Struts2+JasperReport Web报表应用示例                        <font fontName="瀹嬩綋" pdfFontName="STSong-Light" size="14" isPdfEmbedded ="true" pdfEncoding ="UniGB-UCS2-H"/>
调整Struts2+JasperReport Web报表应用示例                    </textElement>
调整Struts2+JasperReport Web报表应用示例                <textFieldExpression   class="java.lang.Integer"><![CDATA[$F{id}]]></textFieldExpression>
调整Struts2+JasperReport Web报表应用示例                </textField>
调整Struts2+JasperReport Web报表应用示例                <textField isStretchWithOverflow="false" isBlankWhenNull="false" evaluationTime="Now" hyperlinkType="None"  hyperlinkTarget="Self" >
调整Struts2+JasperReport Web报表应用示例                    <reportElement
调整Struts2+JasperReport Web报表应用示例                        x="98"
调整Struts2+JasperReport Web报表应用示例                        y="7"
调整Struts2+JasperReport Web报表应用示例                        width="105"
调整Struts2+JasperReport Web报表应用示例                        height="29"
调整Struts2+JasperReport Web报表应用示例                        key="textField-2"/>
调整Struts2+JasperReport Web报表应用示例                    <box topBorder="None" topBorderColor="#000000" leftBorder="None" leftBorderColor="#000000" rightBorder="None" rightBorderColor="#000000" bottomBorder="None" bottomBorderColor="#000000"/>
调整Struts2+JasperReport Web报表应用示例                    <textElement>
调整Struts2+JasperReport Web报表应用示例                        <font fontName="瀹嬩綋" pdfFontName="STSong-Light" size="14" isPdfEmbedded ="true" pdfEncoding ="UniGB-UCS2-H"/>
调整Struts2+JasperReport Web报表应用示例                    </textElement>
调整Struts2+JasperReport Web报表应用示例                <textFieldExpression   class="java.lang.String"><![CDATA[$F{city}]]></textFieldExpression>
调整Struts2+JasperReport Web报表应用示例                </textField>
调整Struts2+JasperReport Web报表应用示例                <textField isStretchWithOverflow="false" isBlankWhenNull="false" evaluationTime="Now" hyperlinkType="None"  hyperlinkTarget="Self" >
调整Struts2+JasperReport Web报表应用示例                    <reportElement
调整Struts2+JasperReport Web报表应用示例                        x="212"
调整Struts2+JasperReport Web报表应用示例                        y="8"
调整Struts2+JasperReport Web报表应用示例                        width="100"
调整Struts2+JasperReport Web报表应用示例                        height="28"
调整Struts2+JasperReport Web报表应用示例                        key="textField-3"/>
调整Struts2+JasperReport Web报表应用示例                    <box topBorder="None" topBorderColor="#000000" leftBorder="None" leftBorderColor="#000000" rightBorder="None" rightBorderColor="#000000" bottomBorder="None" bottomBorderColor="#000000"/>
调整Struts2+JasperReport Web报表应用示例                    <textElement>
调整Struts2+JasperReport Web报表应用示例                        <font fontName="瀹嬩綋" pdfFontName="STSong-Light" size="14" isPdfEmbedded ="true" pdfEncoding ="UniGB-UCS2-H"/>
调整Struts2+JasperReport Web报表应用示例                    </textElement>
调整Struts2+JasperReport Web报表应用示例                <textFieldExpression   class="java.lang.String"><![CDATA[$F{name}]]></textFieldExpression>
调整Struts2+JasperReport Web报表应用示例                </textField>
调整Struts2+JasperReport Web报表应用示例                <textField isStretchWithOverflow="false" isBlankWhenNull="false" evaluationTime="Now" hyperlinkType="None"  hyperlinkTarget="Self" >
调整Struts2+JasperReport Web报表应用示例                    <reportElement
调整Struts2+JasperReport Web报表应用示例                        x="331"
调整Struts2+JasperReport Web报表应用示例                        y="7"
调整Struts2+JasperReport Web报表应用示例                        width="111"
调整Struts2+JasperReport Web报表应用示例                        height="30"
调整Struts2+JasperReport Web报表应用示例                        key="textField-4"/>
调整Struts2+JasperReport Web报表应用示例                    <box topBorder="None" topBorderColor="#000000" leftBorder="None" leftBorderColor="#000000" rightBorder="None" rightBorderColor="#000000" bottomBorder="None" bottomBorderColor="#000000"/>
调整Struts2+JasperReport Web报表应用示例                    <textElement>
调整Struts2+JasperReport Web报表应用示例                        <font fontName="瀹嬩綋" pdfFontName="STSong-Light" size="14" isPdfEmbedded ="true" pdfEncoding ="UniGB-UCS2-H"/>
调整Struts2+JasperReport Web报表应用示例                    </textElement>
调整Struts2+JasperReport Web报表应用示例                <textFieldExpression   class="java.lang.String"><![CDATA[$F{street}]]></textFieldExpression>
调整Struts2+JasperReport Web报表应用示例                </textField>
调整Struts2+JasperReport Web报表应用示例                <line direction="TopDown">
调整Struts2+JasperReport Web报表应用示例                    <reportElement
调整Struts2+JasperReport Web报表应用示例                        x="-30"
调整Struts2+JasperReport Web报表应用示例                        y="37"
调整Struts2+JasperReport Web报表应用示例                        width="593"
调整Struts2+JasperReport Web报表应用示例                        height="0"
调整Struts2+JasperReport Web报表应用示例                        key="line-1"/>
调整Struts2+JasperReport Web报表应用示例                    <graphicElement stretchType="NoStretch"/>
调整Struts2+JasperReport Web报表应用示例                </line>
调整Struts2+JasperReport Web报表应用示例            </band>
调整Struts2+JasperReport Web报表应用示例        </detail>
调整Struts2+JasperReport Web报表应用示例        <columnFooter>
调整Struts2+JasperReport Web报表应用示例            <band height="37"  isSplitAllowed="true" >
调整Struts2+JasperReport Web报表应用示例            </band>
调整Struts2+JasperReport Web报表应用示例        </columnFooter>
调整Struts2+JasperReport Web报表应用示例        <pageFooter>
调整Struts2+JasperReport Web报表应用示例            <band height="50"  isSplitAllowed="true" >
调整Struts2+JasperReport Web报表应用示例                <textField isStretchWithOverflow="false" isBlankWhenNull="false" evaluationTime="Now" hyperlinkType="None"  hyperlinkTarget="Self" >
调整Struts2+JasperReport Web报表应用示例                    <reportElement
调整Struts2+JasperReport Web报表应用示例                        x="98"
调整Struts2+JasperReport Web报表应用示例                        y="18"
调整Struts2+JasperReport Web报表应用示例                        width="138"
调整Struts2+JasperReport Web报表应用示例                        height="23"
调整Struts2+JasperReport Web报表应用示例                        key="textField-8"/>
调整Struts2+JasperReport Web报表应用示例                    <box topBorder="None" topBorderColor="#000000" leftBorder="None" leftBorderColor="#000000" rightBorder="None" rightBorderColor="#000000" bottomBorder="None" bottomBorderColor="#000000"/>
调整Struts2+JasperReport Web报表应用示例                    <textElement textAlignment="Right">
调整Struts2+JasperReport Web报表应用示例                        <font fontName="瀹嬩綋" pdfFontName="STSong-Light" size="12" isPdfEmbedded ="true" pdfEncoding ="UniGB-UCS2-H"/>
调整Struts2+JasperReport Web报表应用示例                    </textElement>
调整Struts2+JasperReport Web报表应用示例                <textFieldExpression   class="java.lang.String"><![CDATA["椤垫暟 " + String.valueOf($V{PAGE_NUMBER}) + " of"]]></textFieldExpression>
调整Struts2+JasperReport Web报表应用示例                </textField>
调整Struts2+JasperReport Web报表应用示例                <textField isStretchWithOverflow="false" isBlankWhenNull="false" evaluationTime="Report" hyperlinkType="None"  hyperlinkTarget="Self" >
调整Struts2+JasperReport Web报表应用示例                    <reportElement
调整Struts2+JasperReport Web报表应用示例                        x="239"
调整Struts2+JasperReport Web报表应用示例                        y="18"
调整Struts2+JasperReport Web报表应用示例                        width="83"
调整Struts2+JasperReport Web报表应用示例                        height="23"
调整Struts2+JasperReport Web报表应用示例                        key="textField-9"/>
调整Struts2+JasperReport Web报表应用示例                    <box topBorder="None" topBorderColor="#000000" leftBorder="None" leftBorderColor="#000000" rightBorder="None" rightBorderColor="#000000" bottomBorder="None" bottomBorderColor="#000000"/>
调整Struts2+JasperReport Web报表应用示例                    <textElement>
调整Struts2+JasperReport Web报表应用示例                        <font fontName="瀹嬩綋" pdfFontName="STSong-Light" size="12" isPdfEmbedded ="true" pdfEncoding ="UniGB-UCS2-H"/>
调整Struts2+JasperReport Web报表应用示例                    </textElement>
调整Struts2+JasperReport Web报表应用示例                <textFieldExpression   class="java.lang.String"><![CDATA[" " + String.valueOf($V{PAGE_NUMBER})]]></textFieldExpression>
调整Struts2+JasperReport Web报表应用示例                </textField>
调整Struts2+JasperReport Web报表应用示例            </band>
调整Struts2+JasperReport Web报表应用示例        </pageFooter>
调整Struts2+JasperReport Web报表应用示例        <lastPageFooter>
调整Struts2+JasperReport Web报表应用示例            <band height="50"  isSplitAllowed="true" >
调整Struts2+JasperReport Web报表应用示例            </band>
调整Struts2+JasperReport Web报表应用示例        </lastPageFooter>
调整Struts2+JasperReport Web报表应用示例        <summary>
调整Struts2+JasperReport Web报表应用示例            <band height="0"  isSplitAllowed="true" >
调整Struts2+JasperReport Web报表应用示例            </band>
调整Struts2+JasperReport Web报表应用示例        </summary>
调整Struts2+JasperReport Web报表应用示例</jasperReport>
调整Struts2+JasperReport Web报表应用示例 

这里需要说明的是,由于俺们中国的中文比较特殊,由此在PDF中显示的时候,需要一些额外的Jar包字体来支持。因此需要下载iTextAsian.jar包,此包专门用于显示亚洲的字符。只不过iReport3.0.0以后就已经含了些包。

三设计JavaBean

由本例中没有使用数据库,而是使用JavaBean作为JRDataSource,来传递给JasperReports作为数据源,因此只需要设计JavaBean。"src"com"sterning"PeopleBean.java的代码很简单,只在字个字段:city、id、name、street,代码如下所示:

调整Struts2+JasperReport Web报表应用示例package com.sterning;
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例public class PeopleBean
调整Struts2+JasperReport Web报表应用示例{
调整Struts2+JasperReport Web报表应用示例    private String city = null;
调整Struts2+JasperReport Web报表应用示例    private Integer id = null;
调整Struts2+JasperReport Web报表应用示例    private String name = null;
调整Struts2+JasperReport Web报表应用示例    private String street = null;
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例    public PeopleBean(
调整Struts2+JasperReport Web报表应用示例        String pcity,
调整Struts2+JasperReport Web报表应用示例        Integer pid,
调整Struts2+JasperReport Web报表应用示例        String pname,
调整Struts2+JasperReport Web报表应用示例        String pstreet
调整Struts2+JasperReport Web报表应用示例        )
调整Struts2+JasperReport Web报表应用示例    {
调整Struts2+JasperReport Web报表应用示例        city = pcity;
调整Struts2+JasperReport Web报表应用示例        id = pid;
调整Struts2+JasperReport Web报表应用示例        name = pname;
调整Struts2+JasperReport Web报表应用示例        street = pstreet;
调整Struts2+JasperReport Web报表应用示例    }
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例    public PeopleBean getMe()
调整Struts2+JasperReport Web报表应用示例    {
调整Struts2+JasperReport Web报表应用示例        return this;
调整Struts2+JasperReport Web报表应用示例    }
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例    public String getCity()
调整Struts2+JasperReport Web报表应用示例    {
调整Struts2+JasperReport Web报表应用示例        return city;
调整Struts2+JasperReport Web报表应用示例    }
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例    public Integer getId()
调整Struts2+JasperReport Web报表应用示例    {
调整Struts2+JasperReport Web报表应用示例        return id;
调整Struts2+JasperReport Web报表应用示例    }
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例    public String getName()
调整Struts2+JasperReport Web报表应用示例    {
调整Struts2+JasperReport Web报表应用示例        return name;
调整Struts2+JasperReport Web报表应用示例    }
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例    public String getStreet()
调整Struts2+JasperReport Web报表应用示例    {
调整Struts2+JasperReport Web报表应用示例        return street;
调整Struts2+JasperReport Web报表应用示例    }
调整Struts2+JasperReport Web报表应用示例}
调整Struts2+JasperReport Web报表应用示例
 

四编译模板

其实表面上说是填充数据,其实就是填充一个List。具体的工具都是交给我们的JasperReports去完成。JasperReports要完成数据的填充工作,要经历将编译(将模板文件.jrxml编译成.jasper文件)、加载(加载.jasper文件)、填充(从数据源中取得数据并填充到.jasper二进制文件中)三大步骤。src"com"sterning"JasperAction.java,其代码如下所示:

调整Struts2+JasperReport Web报表应用示例package com.sterning;
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例import java.io.File;
调整Struts2+JasperReport Web报表应用示例import java.util.ArrayList;
调整Struts2+JasperReport Web报表应用示例import java.util.List;
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例import net.sf.jasperreports.engine.JasperCompileManager;
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例import org.apache.struts2.ServletActionContext;
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例import com.opensymphony.xwork2.ActionSupport;
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例public class JasperAction extends ActionSupport {
调整Struts2+JasperReport Web报表应用示例    private static final long serialVersionUID = 1L;
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例    private List<PeopleBean> myList;
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例    public String execute() throws Exception {
调整Struts2+JasperReport Web报表应用示例        //添加数据
调整Struts2+JasperReport Web报表应用示例        PeopleBean p1=new PeopleBean("长沙", new Integer(9), "李化", "天洒路");
调整Struts2+JasperReport Web报表应用示例        PeopleBean p2=new PeopleBean("长沙", new Integer(22), "王小样", "呆小路564");
调整Struts2+JasperReport Web报表应用示例        PeopleBean p3=new PeopleBean("南昌", new Integer(23), "王奸可", "小顺路");
调整Struts2+JasperReport Web报表应用示例        PeopleBean p4=new PeopleBean("南昌", new Integer(32), "李洒", "顺濉路");
调整Struts2+JasperReport Web报表应用示例        PeopleBean p5=new PeopleBean("武汉", new Integer(39), "张中尖", "天洒路");
调整Struts2+JasperReport Web报表应用示例        PeopleBean p6=new PeopleBean("武汉", new Integer(35), "陈主宁", "天河路564");
调整Struts2+JasperReport Web报表应用示例        myList = new ArrayList<PeopleBean>();
调整Struts2+JasperReport Web报表应用示例        myList.add(p1);
调整Struts2+JasperReport Web报表应用示例        myList.add(p2);
调整Struts2+JasperReport Web报表应用示例        myList.add(p3);
调整Struts2+JasperReport Web报表应用示例        myList.add(p4);
调整Struts2+JasperReport Web报表应用示例        myList.add(p5);
调整Struts2+JasperReport Web报表应用示例        myList.add(p6);
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例        try {
调整Struts2+JasperReport Web报表应用示例            String reportSource;
调整Struts2+JasperReport Web报表应用示例            reportSource = ServletActionContext.getServletContext()
调整Struts2+JasperReport Web报表应用示例                    .getRealPath("/jasper/jasper_template.jrxml");
调整Struts2+JasperReport Web报表应用示例            File parent = new File(reportSource).getParentFile();
调整Struts2+JasperReport Web报表应用示例            //将.jrxml模板文件编译成为.jasper文件,当然,其文件名可以指定,如果没指定,则与.jrxml文件名一样.只是后缀不同而已
调整Struts2+JasperReport Web报表应用示例            JasperCompileManager.compileReportToFile(reportSource, new File(
调整Struts2+JasperReport Web报表应用示例                    parent, "compiled_jasper_template.jasper")
调整Struts2+JasperReport Web报表应用示例                    .getAbsolutePath());
调整Struts2+JasperReport Web报表应用示例        } catch (Exception e) {
调整Struts2+JasperReport Web报表应用示例            e.printStackTrace();
调整Struts2+JasperReport Web报表应用示例            return ERROR;
调整Struts2+JasperReport Web报表应用示例        }
调整Struts2+JasperReport Web报表应用示例        return SUCCESS;
调整Struts2+JasperReport Web报表应用示例    }
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例    public List getMyList() {
调整Struts2+JasperReport Web报表应用示例        return myList;
调整Struts2+JasperReport Web报表应用示例    }
调整Struts2+JasperReport Web报表应用示例}
调整Struts2+JasperReport Web报表应用示例
 

五配置Struts2文件

前面这些工作都是为JasperReports而作的。接下来就是将JasperReports集成到Struts2中。

1. Web.xml

首先是Web.xml。这个文件配置比较简单,也比较常规,没什么好说,代码如下WebRoot"WEB-INF"web.xml:

调整Struts2+JasperReport Web报表应用示例<?xml version="1.0" encoding="UTF-8"?>
调整Struts2+JasperReport Web报表应用示例<web-app version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee"
调整Struts2+JasperReport Web报表应用示例    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
调整Struts2+JasperReport Web报表应用示例    xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee 
调整Struts2+JasperReport Web报表应用示例http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
调整Struts2+JasperReport Web报表应用示例    <filter>
调整Struts2+JasperReport Web报表应用示例        <filter-name>struts2</filter-name>
调整Struts2+JasperReport Web报表应用示例        <filter-class>
调整Struts2+JasperReport Web报表应用示例            org.apache.struts2.dispatcher.FilterDispatcher
调整Struts2+JasperReport Web报表应用示例        </filter-class>
调整Struts2+JasperReport Web报表应用示例        <init-param>
调整Struts2+JasperReport Web报表应用示例            <param-name>config</param-name>
调整Struts2+JasperReport Web报表应用示例            <param-value>
调整Struts2+JasperReport Web报表应用示例                struts-default.xml,struts-plugin.xml,struts.xml
调整Struts2+JasperReport Web报表应用示例            </param-value>
调整Struts2+JasperReport Web报表应用示例        </init-param>
调整Struts2+JasperReport Web报表应用示例    </filter>
调整Struts2+JasperReport Web报表应用示例    <filter-mapping>
调整Struts2+JasperReport Web报表应用示例        <filter-name>struts2</filter-name>
调整Struts2+JasperReport Web报表应用示例        <url-pattern>/*</url-pattern>
调整Struts2+JasperReport Web报表应用示例    </filter-mapping>
调整Struts2+JasperReport Web报表应用示例
调整Struts2+JasperReport Web报表应用示例    <!-- The Welcome File List -->
调整Struts2+JasperReport Web报表应用示例    <welcome-file-list>
调整Struts2+JasperReport Web报表应用示例        <welcome-file>index.jsp</welcome-file>
调整Struts2+JasperReport Web报表应用示例    </welcome-file-list>
调整Struts2+JasperReport Web报表应用示例</web-app>
 

2. struts.xml

按理说struts.xml配置文件应该更加简单,但这里由于集成了JasperReports,所以看上去要复杂一点。先来看代码:src" struts.xml:

调整Struts2+JasperReport Web报表应用示例<?xml version="1.0" encoding="UTF-8" ?>
调整Struts2+JasperReport Web报表应用示例<!DOCTYPE struts PUBLIC
调整Struts2+JasperReport Web报表应用示例    "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
调整Struts2+JasperReport Web报表应用示例    "http://struts.apache.org/dtds/struts-2.0.dtd">
调整Struts2+JasperReport Web报表应用示例<struts>
调整Struts2+JasperReport Web报表应用示例    <package name="default"
调整Struts2+JasperReport Web报表应用示例        extends="struts-default,jasperreports-default">
调整Struts2+JasperReport Web报表应用示例        <action name="PDF" class="com.sterning.JasperAction">
调整Struts2+JasperReport Web报表应用示例            <result name="success" type="jasper">
调整Struts2+JasperReport Web报表应用示例                <param name="location">
调整Struts2+JasperReport Web报表应用示例                    /jasper/compiled_jasper_template.jasper
调整Struts2+JasperReport Web报表应用示例                </param>
调整Struts2+JasperReport Web报表应用示例                <param name="dataSource">myList</param>
调整Struts2+JasperReport Web报表应用示例                <param name="format">PDF</param>
调整Struts2+JasperReport Web报表应用示例            </result>
调整Struts2+JasperReport Web报表应用示例        </action>
调整Struts2+JasperReport Web报表应用示例        <action name="HTML" class="com.sterning.JasperAction">
调整Struts2+JasperReport Web报表应用示例            <result name="success" type="jasper">
调整Struts2+JasperReport Web报表应用示例                <param name="location">
调整Struts2+JasperReport Web报表应用示例                    /jasper/compiled_jasper_template.jasper
调整Struts2+JasperReport Web报表应用示例                </param>
调整Struts2+JasperReport Web报表应用示例                <param name="dataSource">myList</param>
调整Struts2+JasperReport Web报表应用示例                <param name="format">HTML</param>
调整Struts2+JasperReport Web报表应用示例            </result>
调整Struts2+JasperReport Web报表应用示例        </action>
调整Struts2+JasperReport Web报表应用示例        <action name="XML" class="com.sterning.JasperAction">
调整Struts2+JasperReport Web报表应用示例            <result name="success" type="jasper">
调整Struts2+JasperReport Web报表应用示例                <param name="location">
调整Struts2+JasperReport Web报表应用示例                    /jasper/compiled_jasper_template.jasper
调整Struts2+JasperReport Web报表应用示例                </param>
调整Struts2+JasperReport Web报表应用示例                <param name="dataSource">myList</param>
调整Struts2+JasperReport Web报表应用示例                <param name="format">XML</param>
调整Struts2+JasperReport Web报表应用示例            </result>
调整Struts2+JasperReport Web报表应用示例        </action>
调整Struts2+JasperReport Web报表应用示例        <action name="CSV" class="com.sterning.JasperAction">
调整Struts2+JasperReport Web报表应用示例            <result name="success" type="jasper">
调整Struts2+JasperReport Web报表应用示例                <param name="location">
调整Struts2+JasperReport Web报表应用示例                    /jasper/compiled_jasper_template.jasper
调整Struts2+JasperReport Web报表应用示例                </param>
调整Struts2+JasperReport Web报表应用示例                <param name="dataSource">myList</param>
调整Struts2+JasperReport Web报表应用示例                <param name="format">CSV</param>
调整Struts2+JasperReport Web报表应用示例            </result>
调整Struts2+JasperReport Web报表应用示例        </action>
调整Struts2+JasperReport Web报表应用示例        <action name="XLS" class="com.sterning.JasperAction">
调整Struts2+JasperReport Web报表应用示例            <result name="success" type="jasper">
调整Struts2+JasperReport Web报表应用示例                <param name="location">
调整Struts2+JasperReport Web报表应用示例                    /jasper/compiled_jasper_template.jasper
调整Struts2+JasperReport Web报表应用示例                </param>
调整Struts2+JasperReport Web报表应用示例                <param name="dataSource">myList</param>
调整Struts2+JasperReport Web报表应用示例                <param name="format">XLS</param>
调整Struts2+JasperReport Web报表应用示例            </result>
调整Struts2+JasperReport Web报表应用示例        </action>
调整Struts2+JasperReport Web报表应用示例    </package>
调整Struts2+JasperReport Web报表应用示例</struts>
调整Struts2+JasperReport Web报表应用示例 

这里,当调用JasperAction的execute()方法成功后,返回后,可见有三个参数:location告诉JasperReports数据填充类二进制的.jasper文件的位置,dataSource指明使用什么数据源,format指明报表输出的格式。


 

六 页面文件

Index.jsp的代码非常的简单,如下:

调整Struts2+JasperReport Web报表应用示例<%@ page language="java" pageEncoding="GB2312"%>
调整Struts2+JasperReport Web报表应用示例<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
调整Struts2+JasperReport Web报表应用示例<html>
调整Struts2+JasperReport Web报表应用示例    <head>
调整Struts2+JasperReport Web报表应用示例        <title>Struts2+ JasperReports 使用示例</title>
调整Struts2+JasperReport Web报表应用示例    </head>
调整Struts2+JasperReport Web报表应用示例    <body>
调整Struts2+JasperReport Web报表应用示例        <a href="HTML.action">HTML</a>
调整Struts2+JasperReport Web报表应用示例        <br>
调整Struts2+JasperReport Web报表应用示例        <a href="PDF.action">PDF</a>
调整Struts2+JasperReport Web报表应用示例        <br>
调整Struts2+JasperReport Web报表应用示例        <a href="XML.action">XML</a>
调整Struts2+JasperReport Web报表应用示例        <br>
调整Struts2+JasperReport Web报表应用示例        <a href="CSV.action">CSV</a>
调整Struts2+JasperReport Web报表应用示例        <br>
调整Struts2+JasperReport Web报表应用示例        <a href="XLS.action">XLS</a>
调整Struts2+JasperReport Web报表应用示例    </body>
调整Struts2+JasperReport Web报表应用示例</html>
调整Struts2+JasperReport Web报表应用示例
 

七运行效果

1.HTML格式

调整Struts2+JasperReport Web报表应用示例

图2.HTML格式

2.PDF格式

调整Struts2+JasperReport Web报表应用示例
图3.PDF格式

3.XML格式

调整Struts2+JasperReport Web报表应用示例
图4.XML格式

4.Excel格式

调整Struts2+JasperReport Web报表应用示例
图5.Excel格式

转载于:http://www.blogjava.net/sterning/archive/2008/01/02/172317.html 

热点排行