`
gddzmr
  • 浏览: 31048 次
  • 性别: Icon_minigender_1
  • 来自: 上海
文章分类
社区版块
存档分类
最新评论

JasperReport+iReport+Applet+Servlet制作报表

阅读更多

项目是B/S的,标示层使用的是Openlaszlo,客户要求在打印的时候不需要选择打印的纸张类型,报表显示就直接打印,所以我在客户做了一个小应用程序。

需要的jar有:msbase.jar;mssqlserver.jar;msutil.jar;jasperreports-2.0.5-applet.jar;

jasperreports-1.3.3.jar;jasperreports-2.0.5-javaflow.jar

需要使用Ireport设计模板,放在reports目录下,载入*.jasper文件

<%@ page contentType="text/html;charset=UTF-8"%>
<%@page import="java.util.Enumeration"%>
<%@page import="java.net.URLDecoder"%>
<%
   String sql = request.getParameter("sql");
   sql="select * from authors";
   System.out.println("viewer.jsp  =========:"+sql);
  // System.out.println("viewer.jsp  =========:"+new String(condition.getBytes("ISO8859_1"),"UTF-8"));
%>
<html>
	<head>
	</head>
	<body>
		<!--"CONVERTED_APPLET"-->
		<!-- HTML CONVERTER -->
		<object classid="clsid:8AD9C840-044E-11D1-B3E9-00805F499D93"
			codebase="http://java.sun.com/update/1.5.0/jinstall-1_5-windows-i586.cab#Version=5,0,0,5"
			WIDTH="100%" HEIGHT="100%">
			<PARAM NAME=CODE VALUE="ViewerApplet.class">
			<param name="scriptable" value="false">
			<PARAM NAME=CODEBASE VALUE="applet">
			<PARAM NAME=ARCHIVE
				VALUE="jasperreports-2.0.5-javaflow.jar,jasperreports-2.0.5-applet.jar,commons-collections-3.1.jar">
			<param name="type" value="application/x-java-applet;version=1.5">
			<PARAM NAME="sql" VALUE="<%=sql%>">
			<comment>
			<embed type="application/x-java-applet;version=1.5"
				\
            ARCHIVE="jasperreports-2.0.5-javaflow.jar,jasperreports-2.0.5-applet.jar,commons-collections-3.1.jar"
				\
            WIDTH="100%" 
            	\
            HEIGHT="100%"
				\
            CODE="ViewerApplet.class"
				\
            CODEBASE="applet"
				\
            ARCHIVE="jasperreports-2.0.5-javaflow.jar,jasperreports-2.0.5-applet.jar,commons-collections-3.1.jar"
				\
            scriptable="false"
				\
            sql="<%=sql%>"
				\
            scriptable=false
			pluginspage="http://java.sun.com/products/plugin/index.html#download">
				<noembed>
					</XMP>
				</noembed>
			</embed>
			</comment>
		</object>
	</body>
</html>

 做一个ViewerApplet的类,继承JApplet

import java.awt.BorderLayout;
import java.io.PrintWriter;
import java.io.StringWriter;
import java.net.URL;
import java.net.URLEncoder;

import javax.swing.JApplet;
import javax.swing.JOptionPane;

import net.sf.jasperreports.engine.JasperPrint;
import net.sf.jasperreports.engine.util.JRLoader;
import net.sf.jasperreports.view.JRViewer;

public class ViewerApplet extends JApplet {

	public ViewerApplet() {
		initComponents();
	}

	private javax.swing.JPanel pnlMain;

	public void init() {

		try {
			//获取viewer.jsp的sql参数
			String sql = getParameter("sql");
			//使用URLEncoder对sql语句进行encode
			sql = URLEncoder.encode(sql, "UTF-8");
			//提交到servlet,使用servlet访问服务器端数据
			URL url = new URL(getCodeBase(), "../servlet/appletServlet?sql="
					+ sql);
			if (url != null) {
				//获取服务器的传递过来的JasperPrint对象
				JasperPrint jasperPrint = (JasperPrint) JRLoader
						.loadObject(url);
				//创建一个JRViewer
				 JRViewer viewer = new JRViewer(jasperPrint);
				 this.pnlMain.add(viewer, BorderLayout.CENTER);
			}
		} catch (Exception e) {
			StringWriter swriter = new StringWriter();
			PrintWriter pwriter = new PrintWriter(swriter);
			e.printStackTrace(pwriter);
			JOptionPane.showMessageDialog(this, swriter.toString());
		}
	}

	private void initComponents() {// GEN-BEGIN:initComponents
		pnlMain = new javax.swing.JPanel();
		pnlMain.setLayout(new java.awt.BorderLayout());
		getContentPane().add(pnlMain, java.awt.BorderLayout.CENTER);
	}

}

 创建一个AppletServlet类

package com.gddzmr.servlet;

import java.io.IOException;
import java.io.ObjectOutputStream;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.gddzmr.applet.ViewerService;

import net.sf.jasperreports.engine.JasperPrint;

public class AppletServlet extends HttpServlet {
	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {

		doPost(request, response);
	}
	 
	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {

		try {
			//获取一个sql参数
			String sql = request.getParameter("sql");
			
			ViewerService service = new ViewerService();
			//获取JasperPrint对象
			JasperPrint jasperPrint = service.getJasper(request
					.getRealPath("/"), sql);
			//将JasperPrint转化为ObjectOutputStream数据流输出
			response.setContentType("application/octet-stream");
			ServletOutputStream out = response.getOutputStream();
			ObjectOutputStream os = new ObjectOutputStream(out);
			os.writeObject(jasperPrint);
			os.flush();
			os.close();
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

}

创建;AppletService类,用于获取JasperPrint对象

package com.gddzmr.applet;

import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import com.gddzmr.db.DBManager;

import net.sf.jasperreports.engine.JasperFillManager;
import net.sf.jasperreports.engine.JasperPrint;
import net.sf.jasperreports.engine.data.JRMapCollectionDataSource;

public class ViewerService {
	DBManager db = new DBManager();

	public JasperPrint getJasper(String realpath, String sql) throws Exception {
		db.openDB();
		//查询结果集
		ResultSet rs = db.executeQuery(sql);
		db.closeSTDB();
		//将ResultSet转化为一个List<HashMap>数组
		List list = db.getMapList(rs);
		Collection rows = list;
		//获取一个JasperPrint对象
		JasperPrint jasperPrint = setReportCollection(realpath
				+ "\\reports\\inboundReport.jasper", rows);
		return jasperPrint;
	}

	/**
	 * 获取JasperPrint对象
	 * 
	 * @param url
	 * @param list
	 * @return
	 * @throws Exception
	 */
	public JasperPrint setReportCollection(String url, Collection list)
			throws Exception {

		Map parameters = new HashMap();
		JRMapCollectionDataSource dataSource;
		//将list数据集转换为JRMapCollectionDataSource
		dataSource = new JRMapCollectionDataSource(list);
		//使用JasperFillManager填充JasperPrint对象
		JasperPrint jasperPrint = JasperFillManager.fillReport(url, parameters,
				dataSource);
		return jasperPrint;
	}
}

 最后创建一个DBManager获取数据

package com.gddzmr.db;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;

public class DBManager {
	private String driverName = "com.microsoft.jdbc.sqlserver.SQLServerDriver";

	private String url = "jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=pubs";

	private String user = "sa";

	private String password = "";

	private Connection cnn;

	private Statement stat;

	private PreparedStatement ps;

	public DBManager() {
	}

	/**
	 * 新建一个数据库连接
	 * 
	 */
	public void openDB() {
		try {

			// 加载数据连接驱动
			Class.forName(driverName);
			// 获取数据库连接
			cnn = DriverManager.getConnection(url, user, password);
		} catch (Exception e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}

	/**
	 * Statement执行查询语句,返回查询的结果集
	 * 
	 * @param sql
	 * @return
	 */
	public ResultSet executeQuery(String sql) {
		try {
			stat = cnn.createStatement();
			return stat.executeQuery(sql);
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return null;
	}

	/**
	 * Statement执行update,insert,delete语句,返回影响的行数
	 * 
	 * @param sql
	 * @return
	 */
	public int executeUpdate(String sql) {
		try {
			stat = cnn.createStatement();
			return stat.executeUpdate(sql);
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return 0;
	}

	/**
	 * Statement执行存储过程,返回ture/false
	 * 
	 * @param sql
	 * @return
	 */
	public boolean executeProcedural(String sql) {
		try {
			stat = cnn.createStatement();
			return stat.execute(sql);
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return false;
	}

	/**
	 * prepareStatement执行查询语句,返回查询的结果集
	 * 
	 * @param sql
	 * @param list
	 * @return
	 */
	public ResultSet executeQuery(String sql, List list) {
		try {
			ps = cnn.prepareStatement(sql);
			if (list.size() != 0 && list != null) {
				for (int i = 0; i < list.size(); i++) {
					ps.setObject(i + 1, list.get(i));
				}
			}
			return ps.executeQuery(sql);
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return null;
	}

	/**
	 * prepareStatement执行update,insert,delete语句,返回影响的行数
	 * 
	 * @param sql
	 * @param list
	 * @return
	 */
	public int executeUpdate(String sql, List list) {
		try {
			ps = cnn.prepareStatement(sql);
			if (list.size() != 0 && list != null) {
				for (int i = 0; i < list.size(); i++) {
					ps.setObject(i + 1, list.get(i));
				}
			}
			return ps.executeUpdate(sql);
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return 0;
	}

	/**
	 * prepareStatement执行存储过程,返回ture/false
	 * 
	 * @param sql
	 * @param list
	 * @return
	 */
	public boolean executeProcedural(String sql, List list) {
		try {
			ps = cnn.prepareStatement(sql);
			if (list.size() != 0 && list != null) {
				for (int i = 0; i < list.size(); i++) {
					ps.setObject(i + 1, list.get(i));
				}
			}
			return ps.execute(sql);
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return false;
	}

	/**
	 * 关闭数据库连接,释放statment
	 * 
	 */
	public void closeSTDB() {
		try {
			stat.close();
			cnn.close();
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}

	}

	/**
	 * 关闭数据库连接,释放PreparedStatement
	 * 
	 */
	public void closePSDB() {
		try {
			ps.close();
			cnn.close();
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}

	/**
	 * 将ResultSet结果集,转换为List<HashMap>,为创建jasperPrint做准备
	 * @param rs
	 * @return
	 */
	public List getMapList(ResultSet rs) {
		ArrayList<HashMap> list = new ArrayList<HashMap>();
		ArrayList<String> nameList = new ArrayList<String>();
		try {
			// 获取字段名的数组
			ResultSetMetaData md = rs.getMetaData();
			for (int i = 1; i <= md.getColumnCount(); i++) {
				nameList.add(md.getColumnName(i));
			}
			// 根据字段名,获取rs中字段的值
			if (rs != null) {
				while (rs.next()) {
					HashMap map = new HashMap();
					for (int i = 0; i < nameList.size(); i++) {
						map.put(nameList.get(i), rs.getObject(nameList.get(i)));
					}
					list.add(map);
				}
			}

		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return list;
	}

	public static void main(String[] args) {
		DBManager db = new DBManager();
		db.openDB();
		ResultSet rs = db.executeQuery("select * from authors");
		ArrayList<HashMap> list = new ArrayList<HashMap>();
		ArrayList<String> nameList = new ArrayList<String>();
		try {
			// 获取字段名数组
			ResultSetMetaData md = rs.getMetaData();
			for (int i = 1; i <= md.getColumnCount(); i++) {
				nameList.add(md.getColumnName(i));
			}

			if (rs != null) {
				while (rs.next()) {
					HashMap map = new HashMap();
					for (int i = 0; i < nameList.size(); i++) {
						System.out.println(nameList.get(i) + "===="
								+ rs.getObject(nameList.get(i)));
						map.put(nameList.get(i), rs.getObject(nameList.get(i)));
					}
					list.add(map);
				}
			}

		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		db.closeSTDB();

	}
}

 

分享到:
评论
10 楼 水土第一 2014-03-06  
melody_5207 写道
URL url = new URL(getCodeBase(), "../servlet/appletServlet?sql=" 

~~在web.xml里是怎么配置的??

亲,web.xml还要配置applet中的url吗?直接配置单纯的servlet不行吗?
9 楼 melody_5207 2008-11-04  
URL url = new URL(getCodeBase(), "../servlet/appletServlet?sql=" 

~~在web.xml里是怎么配置的??
8 楼 melody_5207 2008-11-04  
longlongriver 写道
melody_5207 写道
longlongriver 写道
JasperReport3已经支持基于flash的报表展示了,可以更灵活的支持B/S下的报表展示了!

  有实例吗?
 


下载的demo就带了一个web应用的样例,很详细!

谢谢~~请问demo什么地方可以下载?
7 楼 longlongriver 2008-10-27  
melody_5207 写道
longlongriver 写道
JasperReport3已经支持基于flash的报表展示了,可以更灵活的支持B/S下的报表展示了!

  有实例吗?
 


下载的demo就带了一个web应用的样例,很详细!
6 楼 melody_5207 2008-10-27  
longlongriver 写道
JasperReport3已经支持基于flash的报表展示了,可以更灵活的支持B/S下的报表展示了!

  有实例吗?
 
5 楼 longlongriver 2008-10-27  
JasperReport3已经支持基于flash的报表展示了,可以更灵活的支持B/S下的报表展示了!
4 楼 melody_5207 2008-10-27  
楼主~~可以告诉一下联系方式吗? 有问题请教
  我的QQ:414902377 MSN:jz_melody328@hotmail.com
   
3 楼 lzmch 2008-10-02  
写这么多,你出的报表是什么样式?取数的逻辑是什么?先简单说说再写,别人也好看明白,你这样一上来就是代码,没什么实际意义。
2 楼 love1907 2008-10-02  
很好、。。。。。。。。。。
1 楼 fengfan2008 2008-05-30  
很好, 楼主能不能发扬开源精神把源码贴出来啊!

相关推荐

    JasperReport+iReport报表开发手册.pdf

    ### JasperReport+iReport 报表开发手册核心知识点详解 #### 一、JasperReport与iReport概述 **JasperReport** 是一款强大的、灵活的报表生成工具,它能够展示丰富的页面内容,并支持将这些内容转换为PDF、HTML或...

    JasperReport+iReport报表开发手册.zip

    它有一个相关的开源工程--IReport,这是一个图形化的辅 助工具,主要用于数据报表设计。JasperReports 完全是由 Java 写成,可以应用于 Java 的应用 程序,包括 J2EE,Web 应用程序中生成动态内容,它主要目的是辅助...

    利用Jasperreport+IReport进行报表开发

    IReport是JasperReport的配套设计工具,它提供了一个图形化用户界面,使得开发者可以方便地设计和编辑报表模板。通过IReport,你可以直观地拖放元素,设置样式,以及预览报表效果,大大简化了报表开发过程。 【报表...

    使用JasperReport+iReport进行WEB开发

    在"使用JasperReport+iReport进行WEB开发"的实践中,首先需要安装并配置iReport,下载并解压后,可以通过它来设计报表模板。模板设计完成后,将其保存为.jrxml文件,这是JasperReport的XML格式,包含了报表的所有...

    jasperreport+ireport+jfreechart文档及代码2

    jasperreport+ireport+jfreechart文档及代码2 jasperreport+ireport+jfreechart文档及代码2 jasperreport+ireport+jfreechart文档及代码2

    Jasperreport+ireport 实践操作及web应用

    JasperReport和iReport是Java世界中常用的报表生成工具,它们可以帮助开发者轻松创建复杂的报表,并在Web应用程序中集成。在JasperReport 2.0.2和iReport 2.0.2版本中,我们可以实现多种功能,包括字段、变量、参数...

    jasperreport+ireport+jfreechart文档及代码1

    jasperreport+ireport+jfreechart文档及代码1 jasperreport+ireport+jfreechart文档及代码1 jasperreport+ireport+jfreechart文档及代码1

    Struts2.0+JasperReport+IReport+Oracle 报表开发

    Struts2.0+JasperReport+IReport+Oracle 报表开发 整个项目打包上传,用MyEclipse导入即可调试使用 含报表文件、数据库表结构及测试数据,项目中解决了PDF中文不显示问题

    Struts2.0+JasperReport+IReport+Oracle 报表开发 2/3

    Struts2.0+JasperReport+IReport+Oracle 报表开发 整个项目打包上传,用MyEclipse导入即可调试使用 含报表文件、数据库表结构及测试数据,项目中解决了PDF中文不显示问题

    JasperReport+iReport报表工具详细开发手册

    通过学习《JasperReport+iReport报表工具详细开发手册》和《iReport-JasperReports报表开发指南》,你可以掌握这两个工具的完整功能和最佳实践,从而提升报表开发的效率和质量。手册中应包含了详细的步骤指导、示例...

    Struts2.0+JasperReport+IReport+Oracle 报表开发 3/3

    Struts2.0+JasperReport+IReport+Oracle 报表开发整个项目打包上传,用MyEclipse导入即可调试使用含报表文件、数据库表结构及测试数据,项目中解决了PDF中文

    JasperReport + IReport 开发文档

    7. **jasperreport+ireport开发java报表入门级教程.pdf**:专门针对Java开发者的入门教程,详细解释如何使用JasperReport和IReport构建报表。 8. **jasperReport.pdf**:可能是一个JasperReport的官方文档或者第三方...

    JasperReport+iReport 报表工具详细开发手册

    ### JasperReport+iReport 报表工具详细开发手册 #### 1. 简介 JasperReport是一款功能强大的报表引擎,适用于Java应用环境。它能够根据预设的模板生成多种格式的报表,如PDF、HTML、Excel等。iReport则是...

    JasperReport+iReport高级报表设计实战

    【JasperReport+iReport 高级报表设计实战】 在IT领域,报表系统是许多企业级应用的核心部分,用于展示和分析数据。JasperReport是一款强大的开源报表生成工具,而iReport则是它的可视化设计界面,降低了报表设计的...

    JasperReport+iReport报表学习资料

    ### JasperReport+iReport 报表学习资料知识点梳理 #### 一、JasperReport与iReport简介 - **JasperReport**:是一款强大的报表生成工具,主要用于解析特定的`.jasper`文件并将其转换为用户友好的报表界面。该工具...

    jasperReport+ireport制作pdf报表教程

    **jasperReport+iReport制作PDF报表步骤** 1. **安装iReport**:首先需要下载并安装iReport工具,设置好JDK环境。 2. **创建数据源**:在iReport中配置数据源,如数据库连接,确保报表能够获取到数据。 3. **设计...

    JasperReport+iReport报表工具

    JasperReport和iReport是Java平台下用于生成报表的工具,它们在企业应用开发中扮演着重要的角色,尤其是在报表的生成、展现和打印方面。JasperReport是一种报表引擎,它能够解析.jasper文件并将其呈现到用户界面中,...

    Jasperreport+ireport学习笔记4

    ### JasperReport与iReport复合报表深度解析 #### 引言 在报表开发领域,JasperReport因其强大的功能和灵活性而受到广泛青睐。结合iReport工具,开发者能够更加便捷地设计和生成复杂报表。本文旨在深入解析...

Global site tag (gtag.js) - Google Analytics