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

相关文章

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

windos server2022里的DFS配置的实现

《windosserver2022里的DFS配置的实现》DFS是WindowsServer操作系统提供的一种功能,用于在多台服务器上集中管理共享文件夹和文件的分布式存储解决方案,本文就来介绍一下wi... 目录什么是DFS?优势:应用场景:DFS配置步骤什么是DFS?DFS指的是分布式文件系统(Distr

NFS实现多服务器文件的共享的方法步骤

《NFS实现多服务器文件的共享的方法步骤》NFS允许网络中的计算机之间共享资源,客户端可以透明地读写远端NFS服务器上的文件,本文就来介绍一下NFS实现多服务器文件的共享的方法步骤,感兴趣的可以了解一... 目录一、简介二、部署1、准备1、服务端和客户端:安装nfs-utils2、服务端:创建共享目录3、服

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

Python实现高效地读写大型文件

《Python实现高效地读写大型文件》Python如何读写的是大型文件,有没有什么方法来提高效率呢,这篇文章就来和大家聊聊如何在Python中高效地读写大型文件,需要的可以了解下... 目录一、逐行读取大型文件二、分块读取大型文件三、使用 mmap 模块进行内存映射文件操作(适用于大文件)四、使用 pand

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一

Python xmltodict实现简化XML数据处理

《Pythonxmltodict实现简化XML数据处理》Python社区为提供了xmltodict库,它专为简化XML与Python数据结构的转换而设计,本文主要来为大家介绍一下如何使用xmltod... 目录一、引言二、XMLtodict介绍设计理念适用场景三、功能参数与属性1、parse函数2、unpa

C#实现获得某个枚举的所有名称

《C#实现获得某个枚举的所有名称》这篇文章主要为大家详细介绍了C#如何实现获得某个枚举的所有名称,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... C#中获得某个枚举的所有名称using System;using System.Collections.Generic;usi

Go语言实现将中文转化为拼音功能

《Go语言实现将中文转化为拼音功能》这篇文章主要为大家详细介绍了Go语言中如何实现将中文转化为拼音功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 有这么一个需求:新用户入职 创建一系列账号比较麻烦,打算通过接口传入姓名进行初始化。想把姓名转化成拼音。因为有些账号即需要中文也需要英