ireport学习笔记---java应用程序中使用报表篇
2013-10-25 13:07
453 查看
在正式开始前,我在上一篇的报表里面加入了一个参数id,如下:
当我们运行报表后,就会生成一个.jasper文件,是.jrxml编译后的文件。我这里的文件是test.jasper
1. 在eclipse里新建一个web工程,工程里面要导入jasperreports- 3.1.2.jar,sqljdbc.jar这两个包
2. 建议一个输入的界面,用户输入用户的id。-------index.html文件:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>index.html</title>
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="this is my page">
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<!--<link rel="stylesheet" type="text/css" href="./styles.css">-->
</head>
<body>
<form action="ireport_html.jsp" id="myform" method="post">
用户ID:
<input name="userId" type="text" width="80">
<br />
<input name="button" type="submit" value="确定" />
</form>
</body>
</html>
3. 建议上一个页面提交后的转向页面---ireport_html.jsp
<%@ page language="java" pageEncoding="UTF-8"%>
<%@ page import="net.sf.jasperreports.engine.JasperRunManager"%>
<%@ page import="javax.naming.*"%>
<%@ page import="java.sql.*"%>
<%@ page import="java.util.*"%>
<%@ page import="java.io.*"%>
<%@ page import="com.microsoft.sqlserver.jdbc.SQLServerDriver"%>
<%@ page import="net.sf.jasperreports.engine.JasperPrint"%>
<%@ page import="net.sf.jasperreports.engine.JasperFillManager"%>
<%@ page import="net.sf.jasperreports.engine.JREmptyDataSource"%>
<%@ page import="net.sf.jasperreports.engine.export.JRXlsExporter"%>
<%@ page import="net.sf.jasperreports.engine.JasperReport"%>
<%@ page import="net.sf.jasperreports.engine.util.JRLoader"%>
<%@ page import="net.sf.jasperreports.engine.export.JRHtmlExporter"%>
<%@ page import="net.sf.jasperreports.engine.JRExporterParameter"%>
<%@ page import="net.sf.jasperreports.engine.export.JRHtmlExporterParameter"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html:html lang="true">
<head>
<html:base />
<title>getData.jsp</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
</head>
<body>
<%
String id = null;
Connection con = null;
String CLASSFORNAME = "com.microsoft.sqlserver.jdbc.SQLServerDriver";
String SERVANDDB = "jdbc:sqlserver://localhost:1433;DatabaseName=test";
String USER = "sa";
String PWD = "123pk";
try {
Class.forName(CLASSFORNAME);
con = DriverManager.getConnection(SERVANDDB, USER, PWD);
} catch (Exception e) {
e.printStackTrace();
}
try {
File reportFile = new File(application
.getRealPath("report/test.jasper"));
JasperReport jasperReport = (JasperReport)JRLoader.loadObject(reportFile.getPath());
Map parameters = new HashMap();
String userId = request.getParameter("userId");
parameters.put("id", userId);
JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, parameters, con);
JRHtmlExporter exporter = new JRHtmlExporter();
StringBuffer sbuffer = new StringBuffer();
Map imagesMap = new HashMap();
session.setAttribute("IMAGES_MAP", imagesMap);
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();
con.close();
} catch (Exception ex) {
out.print("出现例外,信息是:" + ex.getMessage());
ex.printStackTrace();
}
%>
</body>
</html:html>
4.发布运行程序,在页面里面输入用户的id,然后报表程序就显示出来了
当我们运行报表后,就会生成一个.jasper文件,是.jrxml编译后的文件。我这里的文件是test.jasper
1. 在eclipse里新建一个web工程,工程里面要导入jasperreports- 3.1.2.jar,sqljdbc.jar这两个包
2. 建议一个输入的界面,用户输入用户的id。-------index.html文件:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>index.html</title>
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="this is my page">
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<!--<link rel="stylesheet" type="text/css" href="./styles.css">-->
</head>
<body>
<form action="ireport_html.jsp" id="myform" method="post">
用户ID:
<input name="userId" type="text" width="80">
<br />
<input name="button" type="submit" value="确定" />
</form>
</body>
</html>
3. 建议上一个页面提交后的转向页面---ireport_html.jsp
<%@ page language="java" pageEncoding="UTF-8"%>
<%@ page import="net.sf.jasperreports.engine.JasperRunManager"%>
<%@ page import="javax.naming.*"%>
<%@ page import="java.sql.*"%>
<%@ page import="java.util.*"%>
<%@ page import="java.io.*"%>
<%@ page import="com.microsoft.sqlserver.jdbc.SQLServerDriver"%>
<%@ page import="net.sf.jasperreports.engine.JasperPrint"%>
<%@ page import="net.sf.jasperreports.engine.JasperFillManager"%>
<%@ page import="net.sf.jasperreports.engine.JREmptyDataSource"%>
<%@ page import="net.sf.jasperreports.engine.export.JRXlsExporter"%>
<%@ page import="net.sf.jasperreports.engine.JasperReport"%>
<%@ page import="net.sf.jasperreports.engine.util.JRLoader"%>
<%@ page import="net.sf.jasperreports.engine.export.JRHtmlExporter"%>
<%@ page import="net.sf.jasperreports.engine.JRExporterParameter"%>
<%@ page import="net.sf.jasperreports.engine.export.JRHtmlExporterParameter"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html:html lang="true">
<head>
<html:base />
<title>getData.jsp</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
</head>
<body>
<%
String id = null;
Connection con = null;
String CLASSFORNAME = "com.microsoft.sqlserver.jdbc.SQLServerDriver";
String SERVANDDB = "jdbc:sqlserver://localhost:1433;DatabaseName=test";
String USER = "sa";
String PWD = "123pk";
try {
Class.forName(CLASSFORNAME);
con = DriverManager.getConnection(SERVANDDB, USER, PWD);
} catch (Exception e) {
e.printStackTrace();
}
try {
File reportFile = new File(application
.getRealPath("report/test.jasper"));
JasperReport jasperReport = (JasperReport)JRLoader.loadObject(reportFile.getPath());
Map parameters = new HashMap();
String userId = request.getParameter("userId");
parameters.put("id", userId);
JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, parameters, con);
JRHtmlExporter exporter = new JRHtmlExporter();
StringBuffer sbuffer = new StringBuffer();
Map imagesMap = new HashMap();
session.setAttribute("IMAGES_MAP", imagesMap);
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();
con.close();
} catch (Exception ex) {
out.print("出现例外,信息是:" + ex.getMessage());
ex.printStackTrace();
}
%>
</body>
</html:html>
4.发布运行程序,在页面里面输入用户的id,然后报表程序就显示出来了
相关文章推荐
- ireport学习笔记---java应用程序中使用报表篇
- Java学习笔记1:java后台写接口,使用AES和RSA
- 【Java学习笔记】Comparable接口的实现和使用
- [每日学习笔记][2012.07.09]使用Java理解程序逻辑(一)
- 第10课:底实战详解使用Java开发Spark程序学习笔记
- Java学习笔记23. if语句的使用
- Android(java)学习笔记94:关于广播接收者的注册和使用心得
- java泛型编程学习 笔记一:为什么要使用泛型
- [Java Path Finder][JPF学习笔记][8]几篇使用JPF的论文
- java学习笔记 线程池的使用1
- Java for Web学习笔记(一零七):Spring框架中使用JPA(7)密码和BCrypt
- 【学习笔记】系列十三:使用JMeter进行性能测试之Java请求
- Java学习笔记25:Java中MD5使用
- Android(java)学习笔记207:开源项目使用之gif view
- Java学习笔记之使用MyEclipse将java项目打包成jar文件,并生成Javadoc帮助文档
- lua学习笔记 3 android调用Lua。Lua脚本使用LoadLib回调Java,并传多个参数
- [原]Java多线程编程学习笔记之六:使用synchronized获取互斥锁的几点说明
- Java开发工具使用及其快捷键和常见对象+JAVA学习笔记-DAY11
- Android(java)学习笔记128:使用proguard混淆android代码
- Java学习笔记(一):CMD使用