`
uule
  • 浏览: 6359302 次
  • 性别: Icon_minigender_1
  • 来自: 一片神奇的土地
社区版块
存档分类
最新评论

使用报表开发工具Ireport生成Pdf报表的总结

阅读更多

一、个人总结

要使用Ireport,首先都要配置生成模版,小弟到目前为止只用过两种方式,一种是使用JDBC数据源方式,就是在Ireport里写SQL语句,将需要的字段在SQL语句里输出出来,然后再拖拉构造模版文件。当报表比较复杂时,这种情况就需要写一些非常复杂的SQL语句,刚开始学习用Ireport时,以为只能这样生成模版,每天写一大堆SQL,很容易错不说,还弄得人头昏脑胀,痛不欲生啊,所幸,Ireport还有使用JavaBean作为数据源的方式。这两种方式使用起来个人感觉最主要的区别就是

JavaBean方式:

JRDataSource dataSource  = new JRBeanCollectionDataSource(mapList);
JasperReport  jasperReport = (JasperReport) JRLoader.loadObject(file);
jasperPrint = JasperFillManager.fillReport(jasperReport, null, dataSource);

 这种方式使用的是JasperFillManager.fillReport(jasperReport, parameters, dataSource),其中dataSource是通过传入的对象列表List<T>构造的

而JDBC方式:

Class.forName("com.mysql.jdbc.Driver");  
Connection conn= DriverManager.getConnection("jdbc:mysql://localhost/test","root","root");  
JasperFillManager.fillReport(jasperReport, parameters, conn);

 

InputStream inputStream = getServletConfig().getServletContext().getResourceAsStream("report.jasper");           
JasperPrint jasperPrint = JasperFillManager.fillReport(inputStream, parameters,connection);  
 

这这种方式使用的是JasperFillManager.fillReport(jasperReport, parameters, connection)、JasperFillManager.fillReport(inputStream, parameters, connection)最后一个参数是JDBC中的Connection

 

二、生成模版

JDBC方式比较简单,就不介绍了。下面只介绍JavaBean模式(小弟比较懒,下面只讲重点,废话就不多说了):

1、新建一个JavaBean类:

package com.techson.trms.testIeport;

public class CustomBean {
	
	private String city;  
	private Integer id;  
	private String name;  

	public String getCity() {
		return city;
	}
	public void setCity(String city) {
		this.city = city;
	}
	public Integer getId() {
		return id;
	}
	public void setId(Integer id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}	
}

 2、配置Ireport的ClASSPATH为编译好的.class文件的路径 ,如图:


3、指定数据源:

在网上看到许多网友的这步的配置,发现有两种情况,一种是使用默认的数据源,一种是自己配置的数据源,刚开始时,还以为其中有一个错了,后来才发现,其实这根本没有关系的,只不过使用自己配置的数据源的,Preview时可以显示出预览数据,仅此而已。


 

默认数据源:


自己定义的数据源:

新建CustomFactory 数据源类:

public class CustomFactory {

	public static Collection<CustomBean> getBeans(){
		
		List<CustomBean> list = new ArrayList<CustomBean>();
		for(int i = 0 ;i<12;i++){
			CustomBean c = new CustomBean();
			c.setCity("city:"+i);
			c.setId(i+50);
			c.setName("name:"+i);
			list.add(c);
		}		
		return list;
	}
}

 

 

Factory class(the class that will produce the set): 为自己的CustomFactory的全路径。

下面输入的是类中定义的静态方法。

 

4、获取属性

在JavaBeanDataSource中输入自己新建的Bean类的全路径,点“Read Attributes” ,读取属性,选中需要的属性,加入到下面,然后点“OK”:


5、往模版中拖拉属性:


大致意思一下,咱主要说功能,美观方面就先不说了,呵呵。保存,模版文件example.jasper就生成了。可在Ireport中直接编译生成jasper文件,也可由程序自己生成。

 

三、项目中使用模版生成PDF文件

直接上代码:

点击“导出到PDF”

function doExport(){
				var time = new Date();
				window.open("<%=path%>/printEmail.do?doAction=pdf&time="+time,"window","menubar=no,status=no,resizable=no,scrollbars=1,width=800pt,height=600pt,top=100,left=300");
			}
 

进入这个Action(小弟用的是struts1,比较老,呵呵):

	@Override
	public String process(ActionForm form, HttpServletRequest request)
			throws Exception {

		HttpSession session = request.getSession();
		List<CustomBean> list = new ArrayList<CustomBean>();
		for(int i = 0 ;i<12;i++){
			CustomBean c = new CustomBean();
			c.setCity("city:"+i);
			c.setId(i+50);
			c.setName("name:"+i);
			list.add(c);
		}
		String fileName =createPDFByXmlName("example", list, session);
		session.setAttribute("PDFNAME", fileName);
		return "success";
	}
 
	public static String createPDFByXmlName(String reportName, List mapList,HttpSession session) throws UnsupportedEncodingException, JRException {
		String path = "WebRoot/reports";
		if (session != null) {
			path = session.getServletContext().getRealPath("reports");
		}
		JasperReport jasperReport;
		JasperPrint jasperPrint;		
		
		try {
			File file = new File(path + "/" + reportName + ".jasper");
			//如果jasper文件不存在,就调用jrxml文件编译生成
			//JasperCompileManager.compileReportToFile(String sourceFileName, String destFileName)
			if (!file.exists()) {
				JasperCompileManager.compileReportToFile(path + "/"+ reportName + ".jrxml",path + "/"+ reportName + ".jasper");
			}

			jasperReport = (JasperReport) JRLoader.loadObject(file);
			
			JRDataSource dataSource  = new JRBeanCollectionDataSource(mapList);
				//此处为关键,将对象列表设为数据源			
			jasperPrint = JasperFillManager.fillReport(jasperReport, null, dataSource);
				//因模版上没有传入参数,所以此处第二个参数为空

			String fileName = "pdf/"+reportName+session.getId()+".pdf";		
			File fi = new File(path+"/pdf");
			if(!fi.exists()){
				fi.mkdir();
			}			
			//生成方法1
			JRPdfExporter exporter = new JRPdfExporter();
			exporter.setParameter(JRPdfExporterParameter.JASPER_PRINT, jasperPrint);
			exporter.setParameter(JRPdfExporterParameter.CHARACTER_ENCODING,"UTF-8");
			exporter.setParameter(JRPdfExporterParameter.OUTPUT_FILE_NAME, path+"/"+fileName);
								//注意此处用的不是JRPdfExporterParameter.OUTPUT_FILE,要用这个,还需新建File
			exporter.exportReport();
			
			//生成方法2
			try {					
				JasperExportManager.exportReportToPdfFile(jasperPrint,path+"/"+fileName);
			} catch (Exception e) {
				e.printStackTrace();
			}		
			session.getServletContext().setAttribute("FilePath", path+"/pdf");
			return fileName;
		}catch(JRException e){
			e.printStackTrace();			
			throw new JRException(e);
		}
	}

 代码注释里写的很详细了。。。

其实到这就已经介绍完了,不过既然写了,就弄完吧,o(∩_∩)o 哈哈

 

成功后跳转:

<action path="/printEmail" type="com.techson.trms.struts.action.PrintEmailAction">
			<forward name="success" path="/printEmail.jsp" />
		</action>

 printEmail.jsp文件:

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
	org.apache.commons.logging.Log log = org.apache.commons.logging.LogFactory
			.getLog("print.jsp");
	log.warn(" enter print.jsp");
	String path = request.getContextPath();
	String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
  <script type="text/javascript">
  	function init(){
  		var time = new Date();
	  	var url='<%=basePath %>'+"reports/"+'${PDFNAME}'+"?doAction=pdf&time"+time;
  		window.location.href=url;
  	}
  </script>
  </head>
  <body onload="init();">

 


 最后实现的效果是点击导出PDF文件后,弹出一个浏览器框,提示下载。

最后效果:


 

This is  all !  o(∩_∩)o 哈哈

 

另:

实际调试中发现代码到编译jrxml文件为jasper文件时死活过不去,替换了groovy.jar架包为groovy-1.5.7.jar后,还不行,又替换为本文所使用的Ireport3.7.6中的groovy-all-1.7.5.jar,编译通过!Game Over !

  • 大小: 8.7 KB
  • 大小: 43.8 KB
  • 大小: 34.3 KB
  • 大小: 40.1 KB
  • 大小: 59.4 KB
  • 大小: 12.2 KB
  • 大小: 17.5 KB
  • 大小: 76.6 KB
分享到:
评论
4 楼 zzujava0430 2016-05-09  
为何只打印出来第一条数据,其他的都没有打印出来
3 楼 Ginger90 2015-01-26  
其实感觉如果用帆软报表做的话会更简单一些
2 楼 uule 2013-07-04  
架包问题。
不是架包冲突就是架包版本太低。
也可尝试使用高版本Ireport生成模版文件后再加载。
1 楼 Apple_2011 2013-07-01  
jasperReport = (JasperReport) JRLoader.loadObject(file); 跟踪程序,在走到这一步的时候报类转换异常。 请问是怎么了?

相关推荐

    免费的防止锁屏小软件,可用于域统一管控下的锁屏机制

    免费的防止锁屏小软件,可用于域统一管控下的锁屏机制

    Python代码实现带装饰的圣诞树控制台输出

    内容概要:本文介绍了一段简单的Python代码,用于在控制台中输出一棵带有装饰的圣诞树。具体介绍了代码结构与逻辑,包括如何计算并输出树形的各层,如何加入装饰元素以及打印树干。还提供了示例装饰字典,允许用户自定义圣诞树装饰位置。 适用人群:所有对Python编程有一定了解的程序员,尤其是想要学习控制台图形输出的开发者。 使用场景及目标:适用于想要掌握如何使用Python代码创建控制台艺术,特别是对于想要增加节日氛围的小项目。目标是帮助开发者理解和实现基本的字符串操作与格式化技巧,同时享受创造乐趣。 其他说明:本示例不仅有助于初学者理解基本的字符串处理和循环机制,而且还能激发学习者的编程兴趣,通过调整装饰物的位置和树的大小,可以让输出更加个性化和丰富。

    白色大气风格的设计师作品模板下载.zip

    白色大气风格的设计师作品模板下载.zip

    电商平台开发需求文档.doc

    电商平台开发需求文档.doc

    白色简洁风格的办公室室内设计门户网站模板下载.zip

    白色简洁风格的办公室室内设计门户网站模板下载.zip

    VB+access干部档案管理系统(源代码+系统)(20246t).7z

    1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于计算机科学与技术等相关专业,更为适合;

    VB+ACCESS服装专卖店管理系统设计(源代码+系统+开题报告+答辩PPT)(2024ra).7z

    1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于计算机科学与技术等相关专业,更为适合;

    (179065812)基于Android stduio的手机银行开发与设计-用于课程设计

    课程设计---基于Android stduio的手机银行开发与设计 现今,手机已经成为人们生活和工作的必备品,在手机各种系统中Android系统是人们用的比较多的系统。手机银行也是人们在生活中比较常用的功能之一。本项目基于Android的手机银行开发与设计主要功能有登录注册、转账、转账记录查询、修改及查询个人信息、添加好友、向好友转账的功能。本项目主要用Android Studio 开发,数据库SQLite数据库,和夜神模拟器。 基于Android stduio的手机银行开发与设计项目主要功能有登录注册、转账、转账记录查询、修改及查询个人信息、添加好友、向好友转账的功能。。内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。

    白色大气风格的婚礼现场倒计时模板下载.zip

    白色大气风格的婚礼现场倒计时模板下载.zip

    轮式移动机器人轨迹跟踪的MATHLAB程序,运用运动学和动力学模型的双闭环控制,借鉴自抗扰控制技术结合了非线性ESO,跟踪效果良好,控制和抗扰效果较优,可分享控制结构图 这段程序主要是一个小车的动力

    轮式移动机器人轨迹跟踪的MATHLAB程序,运用运动学和动力学模型的双闭环控制,借鉴自抗扰控制技术结合了非线性ESO,跟踪效果良好,控制和抗扰效果较优,可分享控制结构图。 这段程序主要是一个小车的动力学仿真程序,用于模拟小车在参考轨迹下的运动。下面我将对程序进行详细的分析解释。 首先,程序开始时使用`clear`、`clc`和`close all`命令来清除工作空间、命令窗口和图形窗口中的内容。 接下来,程序定义了一系列参数和变量,用于设置仿真的参数和存储仿真过程中的数据。这些参数包括小车的质量、车宽、驱动轮半径等,还有参考轨迹的振幅和频率,仿真步长,仿真时间等。 然后,程序定义了一些元胞数组,用于存储不同阶段的数据。这些数组包括参考轨迹位姿、真实运动轨迹位姿、参考轨迹一阶导数、参考轨迹速度、期望速度、真实速度、控制器输出的控制力矩、控制输入、期望速度与真实速度误差、摩擦值、外界扰动值、总扰动、位姿跟踪误差、扰动观测值等。 接下来,程序给这些变量赋初始值,包括小车的初始位姿和速度,初始速度,期望初始速度,控制器输出的控制力矩,扰动观测值等。 然后,程序进入一个循环,仿真时间从

    vb+ACCESS学生档案管理系统(论文+源代码)(2024ql).7z

    1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于计算机科学与技术等相关专业,更为适合;

    数据分析-31-疫情数据分析(包含代码和数据)

    这是一份来自开源的全球新冠肺炎数据集,每日时间序列汇总,包括确诊、死亡和治愈。所有数据来自每日病例报告。数据持续更新中。 由于数据集中没有美国的治愈数据,所以在统计全球的现有确诊人员和治愈率的时候会有很大误差,代码里面先不做这个处理,期待数据集的完善。

    白色大气风格的时装设计公司模板下载.zip

    白色大气风格的时装设计公司模板下载.zip

    白色大气风格的商务会议活动模板下载.rar

    白色大气风格的商务会议活动模板下载.rar

    vb+access工资管理系统(论文+程序+开题报告+外文翻译+答辩PPT)(2024k3).7z

    1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于计算机科学与技术等相关专业,更为适合;

    基于微信小程序的学生签到系统设计与实现ssm.zip

    本次开发一套基于微信小程序的生签到系统,有管理员,教师,学生三个角色。管理员功能有个人中心,学生管理,教师管理,签到管理,学生签到管理,班课信息管理,加入班课管理,请假信息管理,审批信息管理,销假信息管理,系统管理。教师和学生都可以在微信端注册和登录,教师可以管理签到信息,管理班课信息,审批请假信息,查看学生签到,查看加入班级,查看审批信息和销假信息。学生可以查看教师发布的学生签到信息,可以自己选择加入班课信息,添加请假信息,查看审批信息,进行销假操作。基于微信小程序的生签到系统服务端用Java开发的网站后台,接收并且处理微信小程序端传入的json数据,数据库用到了MySQL数据库作为数据的存储。

    技术资源分享-我的运维人生-《新年的奇妙团聚与希望之旅》

    **脚本描述**:本脚本围绕着新年这个充满欢乐与希望的时刻展开。故事发生在一个热闹的小镇,主要角色有在外打拼多年的年轻人小李,他的父母,以及一群充满活力的小镇居民。新年将至,小李踏上回家的旅途,满心期待与家人团聚。在小镇上,大家都在积极筹备新年,贴春联、挂灯笼、准备年夜饭。小李与家人重逢后,一起分享着彼此的故事和喜悦。同时,他们也和小镇居民一起举办了热闹的庆祝活动,在欢声笑语中迎接新年的到来。这个新年不仅让小李重新感受到了家的温暖,也让他对未来充满了信心和希望,他决定和小镇一起成长发展。通过这个脚本,展现新年带给人们的幸福、温暖和对未来的憧憬。

    Python 自动办公- Python分类汇总278张Excel表中的数据 Python源码

    Python 自动办公- Python分类汇总278张Excel表中的数据

    白色创意风格的用户信息登记源码下载.zip

    白色创意风格的用户信息登记源码下载.zip

    白色大气的音乐专辑博客整站网站模板下载.zip

    白色大气的音乐专辑博客整站网站模板下载.zip

Global site tag (gtag.js) - Google Analytics