iReport+JasperReport+JSP 输出HTML方式预览
2010-05-17 18:29
736 查看
目前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">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
<%
File reportFile = new File(application
.getRealPath("jasper/Test2.jasper"));
JasperReport jasperReport = (JasperReport) JRLoader
.loadObject(reportFile.getPath());
Map parameters = new HashMap();
parameters.put("para1", "AAA");
Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager.getConnection(
"jdbc:mysql://localhost:3306/phpcms", "root", "root");
JasperPrint jasperPrint = JasperFillManager.fillReport(
jasperReport, parameters, conn);
JRHtmlExporter exporter = new JRHtmlExporter();
exporter
.setParameter(JRExporterParameter.JASPER_PRINT, jasperPrint);
exporter.setParameter(JRExporterParameter.OUTPUT_WRITER, out);
exporter.setParameter(JRHtmlExporterParameter.IS_USING_IMAGES_TO_ALIGN, Boolean.FALSE);
exporter.exportReport();
out.flush();
conn.close();
%>
</body>
</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是否正确传递。
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">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
<%
File reportFile = new File(application
.getRealPath("jasper/Test2.jasper"));
JasperReport jasperReport = (JasperReport) JRLoader
.loadObject(reportFile.getPath());
Map parameters = new HashMap();
parameters.put("para1", "AAA");
Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager.getConnection(
"jdbc:mysql://localhost:3306/phpcms", "root", "root");
JasperPrint jasperPrint = JasperFillManager.fillReport(
jasperReport, parameters, conn);
JRHtmlExporter exporter = new JRHtmlExporter();
exporter
.setParameter(JRExporterParameter.JASPER_PRINT, jasperPrint);
exporter.setParameter(JRExporterParameter.OUTPUT_WRITER, out);
exporter.setParameter(JRHtmlExporterParameter.IS_USING_IMAGES_TO_ALIGN, Boolean.FALSE);
exporter.exportReport();
out.flush();
conn.close();
%>
</body>
</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是否正确传递。
相关文章推荐
- iReport+JasperReport+JSP 输出HTML方式预览
- servlet+jasperReport,html预览图表不显示
- iReport+jasperreport创建子表的几种方式(1)
- iReport+jasperreport创建子表的几种方式(1)
- IReport与JasperReport生成HTML报表的线条图片问题
- IReport与JasperReport生成HTML报表的问题
- IReport与JasperReport生成HTML报表的线条图片问题
- IReport与JasperReport生成HTML报表的问题
- IReport与JasperReport生成HTML报表的问题
- ireport+jasperreport 报表html显示
- iReport+jasperreport创建子表的几种方式(2)
- IReport与JasperReport生成HTML报表的线条图片问题
- jasperreport + ireport 导出各种类型文件(word,excel,html,pdf,打印) .
- 【转载】在jsp中调用报表IReport+JasperReport
- Jasperreport 输出pdf格式和html格式
- iReport+JasperReport实现数据库记录导出到html、excel、pdf文档
- 利用JasperReport+iReport进行Web报表开发
- 利用JasperReport+iReport进行Web报表开发
- iReport 和 Jasperreport整合开发web报表向导(3)
- IReport与JasperReport开发详解一