Jasperreports+jaspersoft studio 实现单个或多个jrxml(jasper)文件生成一个pdf文件,并利用Servlet发送该pdf文件到浏览器中展示

本文主要是介绍Jasperreports+jaspersoft studio 实现单个或多个jrxml(jasper)文件生成一个pdf文件,并利用Servlet发送该pdf文件到浏览器中展示,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Jasperreports+jaspersoft studio 实现单个或多个jrxml(jasper)文件生成一个pdf文件,并利用Servlet发送该pdf文件到浏览器中展示;

代码如下:

Demo07.jrxml

<?xml version="1.0" encoding="UTF-8"?>
<!-- Created with Jaspersoft Studio version 6.6.0.final using JasperReports Library version 6.6.0  -->
<jasperReport xmlns="http://jasperreports.sourceforge.net/jasperreports" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://jasperreports.sourceforge.net/jasperreports http://jasperreports.sourceforge.net/xsd/jasperreport.xsd" name="Demo07" pageWidth="595" pageHeight="842" columnWidth="555" leftMargin="20" rightMargin="20" topMargin="20" bottomMargin="20" uuid="0431a06d-749b-411d-8fbf-592aa6b1cca1"><property name="com.jaspersoft.studio.data.defaultdataadapter" value="One Empty Record"/><queryString><![CDATA[]]></queryString><background><band splitType="Stretch"/></background><detail><band height="125" splitType="Stretch"><staticText><reportElement x="148" y="34" width="100" height="30" uuid="2bea566e-a20b-4bd6-abe0-0f7760753a24"/><text><![CDATA[Hello World!]]></text></staticText></band></detail>
</jasperReport>

Demo08.jrxml

<?xml version="1.0" encoding="UTF-8"?>
<!-- Created with Jaspersoft Studio version 6.6.0.final using JasperReports Library version 6.6.0  -->
<jasperReport xmlns="http://jasperreports.sourceforge.net/jasperreports" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://jasperreports.sourceforge.net/jasperreports http://jasperreports.sourceforge.net/xsd/jasperreport.xsd" name="Demo08" pageWidth="595" pageHeight="842" columnWidth="555" leftMargin="20" rightMargin="20" topMargin="20" bottomMargin="20" uuid="eba4c4b3-0a9c-43a5-b941-5f9d359ffaf4"><property name="com.jaspersoft.studio.data.defaultdataadapter" value="One Empty Record"/><queryString><![CDATA[]]></queryString><background><band splitType="Stretch"/></background><detail><band height="125" splitType="Stretch"><staticText><reportElement x="172" y="38" width="100" height="30" uuid="416b6928-db60-40fb-b416-46dbc989203c"/><text><![CDATA[hahahalouu]]></text></staticText></band></detail>
</jasperReport>

JasperServletMul.java

package com.accord.servlet;import java.io.BufferedInputStream;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;import net.sf.jasperreports.engine.JREmptyDataSource;
import net.sf.jasperreports.engine.JRException;
import net.sf.jasperreports.engine.JRExporterParameter;
import net.sf.jasperreports.engine.JasperCompileManager;
import net.sf.jasperreports.engine.JasperFillManager;
import net.sf.jasperreports.engine.JasperPrint;
import net.sf.jasperreports.engine.JasperReport;
import net.sf.jasperreports.engine.JasperRunManager;
import net.sf.jasperreports.engine.data.JRBeanCollectionDataSource;
import net.sf.jasperreports.engine.export.JRPdfExporter;
import net.sf.jasperreports.engine.util.JRLoader;public class JasperServletMul extends HttpServlet {private static final long serialVersionUID = 1L;public JasperServletMul() {super();}public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {doPost(request, response);}@SuppressWarnings("deprecation")public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {ServletContext context = this.getServletConfig().getServletContext(); 	try {//JasperCompileManager.compileReportToFile("E:/report/DbReport.jrxml");String filename = JasperCompileManager.compileReportToFile(context.getRealPath("/jasper/Demo07.jrxml"));String filename02 = JasperCompileManager.compileReportToFile(context.getRealPath("/jasper/Demo08.jrxml"));System.out.println(filename);System.out.println(filename02);} catch (JRException e1) {e1.printStackTrace();}//编译jrxml文件,生成jasper文件// 第一步:装载jasper文件File jasperFileName = new File(context.getRealPath("/jasper/Demo07.jasper"));// 第二步:设置参数值/* 设置参数 */HashMap<String, Object> params2 = new HashMap<String, Object>();// 建立参数表params2.put("name","我们的产品"); // 设置参数值// 第三步:利用JasperRunManager生成PDF文件try {JasperRunManager.runReportToPdfFile(jasperFileName.getPath(),params2, new JREmptyDataSource());} catch (JRException e) {e.printStackTrace();}JRPdfExporter jrpdf = new JRPdfExporter();JasperReport report1 = null;try {report1 = (JasperReport) JRLoader.loadObject(new File(context.getRealPath("/jasper/Demo07.jasper")));} catch (JRException e2) {e2.printStackTrace();}JasperReport report2 = null;try {report2 = (JasperReport) JRLoader.loadObject(new File(context.getRealPath("/jasper/Demo08.jasper")));} catch (JRException e1) {e1.printStackTrace();}List<String> list = new ArrayList<String>();list.add("测试数据");JRBeanCollectionDataSource ds1 = new JRBeanCollectionDataSource(list);JRBeanCollectionDataSource ds2 = new JRBeanCollectionDataSource(list);HashMap<String, Object> params = new HashMap<String, Object>();// 建立参数表params.put("name", "我们的产品"); // 设置参数值JasperPrint jasperPrint = null;try {jasperPrint = JasperFillManager.fillReport(report1,params,ds1);} catch (JRException e1) {e1.printStackTrace();}JasperPrint jasperPrint2 = null;try {jasperPrint2 = JasperFillManager.fillReport(report2,params,ds2);} catch (JRException e1) {e1.printStackTrace();}List jasperPrintList = new ArrayList();jasperPrintList.add(jasperPrint);jasperPrintList.add(jasperPrint2);String filename = context.getRealPath("/jasper/")+"/" + (System.currentTimeMillis() + "" )+ ".pdf";File file = new File(filename);ByteArrayOutputStream baos = new ByteArrayOutputStream();JRPdfExporter exporter = new JRPdfExporter();exporter.setParameter(JRExporterParameter.JASPER_PRINT_LIST, jasperPrintList);exporter.setParameter(JRExporterParameter.OUTPUT_STREAM, baos);try {exporter.exportReport();} catch (JRException e1) {e1.printStackTrace();}byte[] bytes = baos.toByteArray();// 确定写出文件的位置try {// 建立输出字节流FileOutputStream fos = new FileOutputStream(file);// 用FileOutputStream 的write方法写入字节数组fos.write(bytes);System.out.println("写入成功");// 为了节省IO流的开销,需要关闭fos.close();} catch (FileNotFoundException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();}//下面代码是实现在浏览器中显示pdf文件 开始://设置发送到客户端响应的内容类型,浏览器会根据不同的MIME,调用不同的模块处理response.setContentType("application/pdf");ServletOutputStream out = response.getOutputStream();File pdf = null;BufferedInputStream buf = null;try {pdf = new File(filename);response.setContentLength((int)pdf.length());FileInputStream input = new FileInputStream(pdf);//带缓冲区的输入流//FileInputStream是字节流,BufferedInputStream是字节缓冲流,使用BufferedInputStream读资源比FileInputStream读取资源的效率高buf = new BufferedInputStream(input);int readBytes = 0;while((readBytes=buf.read())!=-1) {out.write(readBytes);}} catch (Exception e) {System.out.println("文件没有找到");} finally {if(out!=null) {out.close();}if(buf!=null) {buf.close();}}//上面代码是实现在浏览器中显示pdf文件 结束:	}
}

pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"><modelVersion>4.0.0</modelVersion><groupId>JasperReports</groupId><artifactId>JasperReports02</artifactId><packaging>war</packaging><version>0.0.1-SNAPSHOT</version><name>JasperReports02 Maven Webapp</name><url>http://maven.apache.org</url><dependencies><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>3.8.1</version><scope>test</scope></dependency><dependency>  <groupId>net.sf.jasperreports</groupId>  <artifactId>jasperreports</artifactId>  <version>5.6.0</version>  </dependency> <dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.30</version></dependency><!-- 解决中文乱码 --><dependency> <groupId>com.lowagie</groupId><artifactId>itextasian</artifactId><version>1.5.2</version></dependency><dependency><groupId>javax.servlet</groupId><artifactId>servlet-api</artifactId><version>2.5</version></dependency></dependencies><build><finalName>JasperReports02</finalName></build>
</project>

web.xml

<!DOCTYPE web-app PUBLIC"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN""http://java.sun.com/dtd/web-app_2_3.dtd" ><web-app><display-name>Archetype Created Web Application</display-name><servlet><servlet-name>JasperServlet</servlet-name><display-name>JasperServlet</display-name><description></description><servlet-class>com.accord.servlet.JasperServlet</servlet-class></servlet><servlet><servlet-name>JasperServletDb</servlet-name><display-name>JasperServletDb</display-name><description></description><servlet-class>com.accord.servlet.JasperServletDb</servlet-class></servlet><servlet><servlet-name>JasperServletJavaBean</servlet-name><display-name>JasperServletJavaBean</display-name><description></description><servlet-class>com.accord.servlet.JasperServletJavaBean</servlet-class></servlet><servlet><servlet-name>JasperServletJavaBeanGroup</servlet-name><display-name>JasperServletJavaBeanGroup</display-name><description></description><servlet-class>com.accord.servlet.JasperServletJavaBeanGroup</servlet-class></servlet><servlet><servlet-name>JasperServletTable</servlet-name><display-name>JasperServletTable</display-name><description></description><servlet-class>com.accord.servlet.JasperServletTable</servlet-class></servlet><servlet><servlet-name>JasperServletChart</servlet-name><display-name>JasperServletChart</display-name><description></description><servlet-class>com.accord.servlet.JasperServletChart</servlet-class></servlet><servlet><servlet-name>JasperServletChart02</servlet-name><display-name>JasperServletChart02</display-name><description></description><servlet-class>com.accord.servlet.JasperServletChart02</servlet-class></servlet><servlet><servlet-name>JasperServletCh</servlet-name><display-name>JasperServletCh</display-name><description></description><servlet-class>com.accord.servlet.JasperServletCh</servlet-class></servlet><servlet><servlet-name>JasperServletMul</servlet-name><display-name>JasperServletMul</display-name><description></description><servlet-class>com.accord.servlet.JasperServletMul</servlet-class></servlet><servlet-mapping><servlet-name>JasperServlet</servlet-name><url-pattern>/JasperServlet</url-pattern></servlet-mapping><servlet-mapping><servlet-name>JasperServletDb</servlet-name><url-pattern>/JasperServletDb</url-pattern></servlet-mapping><servlet-mapping><servlet-name>JasperServletJavaBean</servlet-name><url-pattern>/JasperServletJavaBean</url-pattern></servlet-mapping><servlet-mapping><servlet-name>JasperServletJavaBeanGroup</servlet-name><url-pattern>/JasperServletJavaBeanGroup</url-pattern></servlet-mapping><servlet-mapping><servlet-name>JasperServletTable</servlet-name><url-pattern>/JasperServletTable</url-pattern></servlet-mapping><servlet-mapping><servlet-name>JasperServletChart</servlet-name><url-pattern>/JasperServletChart</url-pattern></servlet-mapping><servlet-mapping><servlet-name>JasperServletChart02</servlet-name><url-pattern>/JasperServletChart02</url-pattern></servlet-mapping><servlet-mapping><servlet-name>JasperServletCh</servlet-name><url-pattern>/JasperServletCh</url-pattern></servlet-mapping><servlet-mapping><servlet-name>JasperServletMul</servlet-name><url-pattern>/JasperServletMul</url-pattern></servlet-mapping>
</web-app>

浏览器访问如下:

以上就完成了:

这篇关于Jasperreports+jaspersoft studio 实现单个或多个jrxml(jasper)文件生成一个pdf文件,并利用Servlet发送该pdf文件到浏览器中展示的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1146940

相关文章

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

Python+PyQt5实现多屏幕协同播放功能

《Python+PyQt5实现多屏幕协同播放功能》在现代会议展示、数字广告、展览展示等场景中,多屏幕协同播放已成为刚需,下面我们就来看看如何利用Python和PyQt5开发一套功能强大的跨屏播控系统吧... 目录一、项目概述:突破传统播放限制二、核心技术解析2.1 多屏管理机制2.2 播放引擎设计2.3 专

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很

java中使用POI生成Excel并导出过程

《java中使用POI生成Excel并导出过程》:本文主要介绍java中使用POI生成Excel并导出过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录需求说明及实现方式需求完成通用代码版本1版本2结果展示type参数为atype参数为b总结注:本文章中代码均为

在java中如何将inputStream对象转换为File对象(不生成本地文件)

《在java中如何将inputStream对象转换为File对象(不生成本地文件)》:本文主要介绍在java中如何将inputStream对象转换为File对象(不生成本地文件),具有很好的参考价... 目录需求说明问题解决总结需求说明在后端中通过POI生成Excel文件流,将输出流(outputStre

idea中创建新类时自动添加注释的实现

《idea中创建新类时自动添加注释的实现》在每次使用idea创建一个新类时,过了一段时间发现看不懂这个类是用来干嘛的,为了解决这个问题,我们可以设置在创建一个新类时自动添加注释,帮助我们理解这个类的用... 目录前言:详细操作:步骤一:点击上方的 文件(File),点击&nbmyHIgsp;设置(Setti

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

MySQL大表数据的分区与分库分表的实现

《MySQL大表数据的分区与分库分表的实现》数据库的分区和分库分表是两种常用的技术方案,本文主要介绍了MySQL大表数据的分区与分库分表的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. mysql大表数据的分区1.1 什么是分区?1.2 分区的类型1.3 分区的优点1.4 分

一文详解如何从零构建Spring Boot Starter并实现整合

《一文详解如何从零构建SpringBootStarter并实现整合》SpringBoot是一个开源的Java基础框架,用于创建独立、生产级的基于Spring框架的应用程序,:本文主要介绍如何从... 目录一、Spring Boot Starter的核心价值二、Starter项目创建全流程2.1 项目初始化(

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T