iReport+JasperReport+JSP 输出HTML方式预览

本文介绍如何使用JasperReport 3.7.2及iReport进行报表设计,并通过JSP实现HTML预览。详细展示了从创建数据源、设计报表模板到部署应用的全过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  目前JasperReport最新版本是3.7.2,iReport也有同步版本更新。今天试用了一下,并用JSP生成HTML预览,代码如下:

 1 <%@ page language="java" contentType="text/html; charset=UTF-8"
 2     pageEncoding="UTF-8"%>
 3 <%@ page
 4     import="java.io.*,
 5             net.sf.jasperreports.engine.*,
 6             net.sf.jasperreports.engine.util.*,
 7             java.util.*,java.sql.*,
 8             net.sf.jasperreports.engine.export.*"%>
 9 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
10 <html>
11 <head>
12 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
13 <title>Insert title here</title>
14 </head>
15 <body>
16 <%
17     File reportFile = new File(application
18             .getRealPath("jasper/Test2.jasper"));
19     JasperReport jasperReport = (JasperReport) JRLoader
20             .loadObject(reportFile.getPath());
21     Map parameters = new HashMap();
22     parameters.put("para1""AAA");
23     Class.forName("com.mysql.jdbc.Driver");
24     Connection conn = DriverManager.getConnection(
25             "jdbc:mysql://localhost:3306/phpcms""root""root");
26     JasperPrint jasperPrint = JasperFillManager.fillReport(
27             jasperReport, parameters, conn);
28     JRHtmlExporter exporter = new JRHtmlExporter();
29     exporter
30             .setParameter(JRExporterParameter.JASPER_PRINT, jasperPrint);
31     exporter.setParameter(JRExporterParameter.OUTPUT_WRITER, out);
32     
33     exporter.setParameter(JRHtmlExporterParameter.IS_USING_IMAGES_TO_ALIGN, Boolean.FALSE);
34     exporter.exportReport();
35     out.flush();    
36     conn.close();
37 %>
38 </body>
39 </html>

 

 

  首先,需使用iReport制作模板,我使用的是本机Mysql数据源,取得数据库phpcms中的某个表的数据,模板字段根据SQL语句自动生成,同时手工新建一个模板变量“para1”,作为生成报表时实时变量传递。最后编译模板,生成Test2.jasper文件;

  然后打开Eclipse JEE,新建Dynamic Web Project,将Test2.jasper拷贝到项目目录webContent/jasper下,引入commons-collections.jar,commons-digester.jar,commons-logging.jar,jasperreport-3.7.2.jar,log4j.jar,mysql-connector-java.jar包,一定要引入这些包,不然似乎是无法运行起来的。

 

注意,如果异常提示找不到Groovy相关的类,请不要盲目的去引入Groovy包,先确认自己的模板里是否有使用Groovy脚步,如果没有的话,请检查自己的xml模板文件(*.jrxml)中jasperReport标签配置项里关于language的设置,如果是groovy,请修改为java即可。本来这个是可以通过设置iReport的全局选项的语言项来搞定,不过我尝试过修改为Java好像也不管用,不知道是否是iReport的bug

 

  最后,用浏览器打开验证报表生成情况,并看para1是否正确传递。 

转载于:https://www.cnblogs.com/micki/archive/2010/05/17/1737592.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值