`

使用JavaBean构造JasperReport子报表

阅读更多

使用JavaBean作为数据源构造JasperReport子报表样式如下:

 

构造我的JavaBean如下(get,set方法省略):

public class Person {

	private String name;

	private String age;

	private String sex;

	private String telephone;
}

 

public class Depart {
	private String subTitle;

	private String depart_name;

	private List<Person> personList = null;
}

 构造我们的Service:

 

public class DepartService {
	public List<Depart> getAllDepart() {
		List<Depart> departList = new ArrayList<Depart>();

		List<Person> personList = null;

		Depart depart = new Depart("测试一", "开发部");
		personList = new ArrayList<Person>();
		personList.add(new Person("小博", "22", "男", "123456"));
		personList.add(new Person("张三", "21", "男", "321456"));
		personList.add(new Person("李四", "24", "女", "654321"));
		personList.add(new Person("王五", "23", "男", "123456"));
		depart.setPersonList(personList);
		departList.add(depart);

		depart = new Depart("测试二", "研发部");
		personList = new ArrayList<Person>();
		personList.add(new Person("小博", "22", "男", "123456"));
		personList.add(new Person("李四", "24", "女", "654321"));
		depart.setPersonList(personList);
		departList.add(depart);

		departList.add(depart);
		return departList;
	}
}

 构造我们的Servlet:

public class JRPDFServlet extends HttpServlet {

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

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		DepartService departMght = new DepartService();
		List<Depart> departList = departMght.getAllDepart();

		ServletContext servletContext = this.getServletConfig().getServletContext();
		File departJasperFile = new File(servletContext.getRealPath("/jasper/Main_Department_List.jasper"));
		// 设置子报表的路径
		String root_path = servletContext.getRealPath("/");
		root_path = root_path.replace("\\", "\\\\");
		root_path = root_path + "jasper\\\\";

		Map<String, String> parameters = new HashMap<String, String>();
		JasperPrint jasperPrint = null;
		try {
			JasperReport departJasperReport = (JasperReport) JRLoader
					.loadObject(departJasperFile.getPath());
			parameters.put("SUBREPORT_DIR", root_path);
			jasperPrint = JasperFillManager.fillReport(departJasperReport,
					parameters, new JRBeanCollectionDataSource(departList));

		} catch (JRException e) {
			e.printStackTrace();
		}
		if (null != jasperPrint) {
			FileBufferedOutputStream fbos = new FileBufferedOutputStream();
			JRPdfExporter exporter = new JRPdfExporter();
			exporter.setParameter(JRExporterParameter.OUTPUT_STREAM, fbos);
			exporter
					.setParameter(JRExporterParameter.JASPER_PRINT, jasperPrint);
			try {
				exporter.exportReport();
				fbos.close();
				if (fbos.size() > 0) {
					response.setContentType("application/pdf");
					response.setContentLength(fbos.size());
					ServletOutputStream ouputStream = response
							.getOutputStream();
					try {
						fbos.writeData(ouputStream);
						fbos.dispose();
						ouputStream.flush();
					} finally {
						if (null != ouputStream) {
							ouputStream.close();
						}
					}
				}
			} catch (JRException e1) {
				e1.printStackTrace();
			} finally {
				if (null != fbos) {
					fbos.close();
					fbos.dispose();
				}
			}
		}
	}
}

 

在web.xml配置servlet如下:

<servlet>
		<servlet-name>JRPDFServlet</servlet-name>
		<servlet-class>com.mengya.servlet.JRPDFServlet</servlet-class>
	</servlet>
	<servlet-mapping>
		<servlet-name>JRPDFServlet</servlet-name>
		<url-pattern>/JRSubPDFServlet</url-pattern>
	</servlet-mapping>

 页面调用:

<h3 align="center"><a href="JRSubPDFServlet">子表报</a></h3>

 

主要是报表设计如下面附件图片。

  • lib1.rar (5.8 MB)
  • 描述: 所需要jar包1
  • 下载次数: 514
  • lib2.rar (6.5 MB)
  • 描述: 所需要jar包2
  • 下载次数: 894
  • 大小: 27.5 KB
  • 大小: 10.3 KB
  • 大小: 20.3 KB
  • 大小: 22.2 KB
  • 大小: 41.2 KB
  • 大小: 49.8 KB
  • 大小: 43.7 KB
12
1
分享到:
评论
7 楼 yang_123 2015-01-04  
谢谢,正在学jasper
6 楼 雨过有痕 2012-11-08  
楼主,在加载报表模板的时候报错啊?
java.lang.NoClassDefFoundError: Lorg/apache/commons/logging/Log;
java.lang.Class.getDeclaredFields0(Native Method)
java.lang.Class.privateGetDeclaredFields(Class.java:2291)
java.lang.Class.getDeclaredField(Class.java:1880)
java.io.ObjectStreamClass.getDeclaredSUID(ObjectStreamClass.java:1610)
java.io.ObjectStreamClass.access$700(ObjectStreamClass.java:52)
java.io.ObjectStreamClass$2.run(ObjectStreamClass.java:425)
java.security.AccessController.doPrivileged(Native Method)
java.io.ObjectStreamClass.<init>(ObjectStreamClass.java:413)
java.io.ObjectStreamClass.lookup(ObjectStreamClass.java:310)
java.io.ObjectStreamClass.initNonProxy(ObjectStreamClass.java:547)
java.io.ObjectInputStream.readNonProxyDesc(ObjectInputStream.java:1583)
java.io.ObjectInputStream.readClassDesc(ObjectInputStream.java:1496)
java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1732)
java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1329)
java.io.ObjectInputStream.defaultReadFields(ObjectInputStream.java:1947)
java.io.ObjectInputStream.readSerialData(ObjectInputStream.java:1871)
java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1753)
java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1329)
java.io.ObjectInputStream.readArray(ObjectInputStream.java:1667)
java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1323)
java.io.ObjectInputStream.defaultReadFields(ObjectInputStream.java:1947)
java.io.ObjectInputStream.readSerialData(ObjectInputStream.java:1871)
java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1753)
java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1329)
java.io.ObjectInputStream.defaultReadFields(ObjectInputStream.java:1947)
java.io.ObjectInputStream.defaultReadObject(ObjectInputStream.java:480)
net.sf.jasperreports.engine.base.JRBaseReport.readObject(JRBaseReport.java:736)
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
java.lang.reflect.Method.invoke(Method.java:597)
java.io.ObjectStreamClass.invokeReadObject(ObjectStreamClass.java:974)
java.io.ObjectInputStream.readSerialData(ObjectInputStream.java:1849)
java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1753)
java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1329)
java.io.ObjectInputStream.readObject(ObjectInputStream.java:351)
net.sf.jasperreports.engine.util.JRLoader.loadObject(JRLoader.java:94)
net.sf.jasperreports.engine.util.JRLoader.loadObject(JRLoader.java:70)
com.mengya.servlet.JRPDFServlet.doPost(JRPDFServlet.java:52)
com.mengya.servlet.JRPDFServlet.doGet(JRPDFServlet.java:33)
javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
javax.servlet.http.HttpServlet.service(HttpServlet.java:722)



5 楼 hunter3900 2012-08-26  
感激不尽,正在学jasper
4 楼 wqxiea 2012-03-13  
太谢谢,非常感谢!
3 楼 jiayang 2010-11-05  
再傻傻的问一句
dataset 可以用javabean作数据源吗?
ireport的面板上好像可以设置,执行时总是在报
警告The supplied java.sql.Connection object is null.
javabean的内容也不出来.
2 楼 jiayang 2010-11-05  
学习了。
我用JavaBean作为数据源构造table控件时,
模板编译时总是报Field not found
不用table控件时,就不会报错。
不知道差在哪里?
可以给点建议吗?
1 楼 xuguozhuu 2010-08-20  
太棒了,今天我也遇到这个问题了,幸好有你的博文!十分感谢!

相关推荐

Global site tag (gtag.js) - Google Analytics