springboot使用jasper实现报表demo
概述
业务中尝尝需要用到报表数据的渲染和导出.报表的配置势必不能写死,需要动态配置。
现成的JasperReports + Jaspersoft Studio即可实现可配置的报表。
报表布局Jaspersoft Studio
https://community.jaspersoft.com/community-download
下载布局工具,我的pc是win系统,直接下载了exe直接安装了
创建布局项目
- File->New->Project先创建一个项目
- 然后继续File->New->Jasper Report(也可以直接在demo项目上右键New->Jasper
Report),选择一个竖向A4纸大小的模板
设计界面展示
Title
:标题区,如果数据有多页只会在第一页打印Page Header
:页头区,多页的情况下每页都会打印Column Header
:列头区,配合下面的Detail
区打印列表数据,多页的情况下每页都会打印Detail
:可以新增多个Detail
区,可以组合打印出多个列表数据,多页的情况下每页都会打印Column Footer
:列表底部区,多页的情况下每页都会打印Page Footer
:页底部区,多页的情况下每页都会打印Summary
:合计区,只会在最后一页打印
创建完项目后–报表demo
- 从右侧
Basic Elements
区域拖拽一个Static Text
元素到Title
区,选中元素后,可以在右侧设置元素的边框,字体和大小,文本的对齐方式等等。 - 在左侧
Outline
区域Paramters
上右键Create Paramter
创建一个新的属性,命名为name
,类型java.lang.String
- 拖拽
name
属性到Page Header
区域,同样可以在右侧设置它的属性 - 在左侧
Outline
区域Fields
上右键Create Field
创建两个字段Field1,Field2
,类型java.lang.String
- 然后拖拽
Field1,Field2
字段到Detail1
区域,会自动带出两个值为Field1,Field2
的Static Text
元素在Column Header
区域,调整位置对齐 - 右键
jrxml
文件可以预览看看样式,因为此时我们未给Field1,Field2
的数据集赋值,所以预览的为null - 在
jrxml
文件上右键Compile Report
可以生成编译生成jasper
文件
操作图例
设置title
添加Paramters
设置Paramters
设置field
预览
添加图片
需要在field或者Paramters,我在demo中是设置的field
变量名需要和上面设置的field变量名对上
编译
springboot中调用模板
引入依赖
<dependency><groupId>net.sf.jasperreports</groupId><artifactId>jasperreports</artifactId><version>6.20.0</version>
</dependency>
工具类
package com.fchan.jasper.util;import lombok.extern.slf4j.Slf4j;
import net.sf.jasperreports.engine.*;
import net.sf.jasperreports.engine.data.JRBeanCollectionDataSource;
import net.sf.jasperreports.engine.export.HtmlExporter;
import net.sf.jasperreports.export.HtmlExporterOutput;
import net.sf.jasperreports.export.SimpleExporterInput;
import net.sf.jasperreports.export.SimpleHtmlExporterOutput;
import net.sf.jasperreports.export.SimpleHtmlReportConfiguration;
import org.springframework.core.io.ClassPathResource;import javax.servlet.http.HttpServletResponse;
import java.io.File;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.util.List;
import java.util.Map;/*** Author: xyyz150* Date: 2020/4/9 19:40* Description:*/
@Slf4j
public class JasperReportUtil {final static String jasperDir = "jaspers";public static String getJasperFileDir(String fileName) {return jasperDir + File.separator + fileName + ".jasper";}private static String getContentType(ReportType type) {String contentType;switch (type) {case HTML:contentType = "text/html;charset=utf-8";break;case PDF:contentType = "application/pdf";break;case XLS:contentType = "application/vnd.ms-excel";break;case XLSX:contentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";break;case XML:contentType = "text/xml";break;case RTF:contentType = "application/rtf";break;case CSV:contentType = "text/plain";break;case DOC:contentType = "application/msword";break;default:contentType = "text/html;charset=utf-8";}return contentType;}static JasperPrint getJasperPrint(InputStream jasperStream, Map parameters, List<?> list) throws JRException {JRDataSource dataSource = null;if (null == list || list.size() == 0) {dataSource = new JREmptyDataSource();} else {dataSource = new JRBeanCollectionDataSource(list);}JasperPrint jasperPrint = JasperFillManager.fillReport(jasperStream, parameters, dataSource);return jasperPrint;}public static void exportToPdf(String jasperPath, Map parameters, List<?> list, HttpServletResponse response) throws Exception {OutputStream outputStream = response.getOutputStream();try {ClassPathResource resource = new ClassPathResource(jasperPath);response.setContentType(getContentType(ReportType.PDF));InputStream jasperStream = resource.getInputStream();JasperPrint jasperPrint = getJasperPrint(jasperStream, parameters, list);JasperExportManager.exportReportToPdfStream(jasperPrint, outputStream);} catch (Exception e) {log.error("读取报表异常", e);outputStream.write("读取报表异常".getBytes());} finally {outputStream.flush();outputStream.close();}}public static void exportToXml(String jasperPath, Map parameters, List<?> list, HttpServletResponse response) throws Exception {OutputStream outputStream = response.getOutputStream();try {ClassPathResource resource = new ClassPathResource(jasperPath);response.setContentType(getContentType(ReportType.XML));InputStream jasperStream = resource.getInputStream();JasperPrint jasperPrint = getJasperPrint(jasperStream, parameters, list);JasperExportManager.exportReportToXmlStream(jasperPrint, outputStream);} catch (Exception e) {log.error("读取报表异常", e);outputStream.write("读取报表异常".getBytes());} finally {outputStream.flush();outputStream.close();}}public static void exportToHtml(String jasperPath, Map parameters, List<?> list, HttpServletResponse response) throws Exception {response.setHeader("Content-type", "text/html;charset=utf-8");response.setCharacterEncoding("utf-8");response.setContentType(getContentType(ReportType.HTML));PrintWriter out = response.getWriter();HtmlExporter exporter = new HtmlExporter();try {ClassPathResource resource = new ClassPathResource(jasperPath);InputStream jasperStream = resource.getInputStream();JasperPrint jasperPrint = getJasperPrint(jasperStream, parameters, list);exporter.setExporterInput(new SimpleExporterInput(jasperPrint));SimpleHtmlReportConfiguration configuration = new SimpleHtmlReportConfiguration();exporter.setConfiguration(configuration);HtmlExporterOutput outPut = new SimpleHtmlExporterOutput(out);exporter.setExporterOutput(outPut);exporter.exportReport();} catch (Exception e) {log.error("读取报表异常", e);out.write("读取报表异常");} finally {out.flush();out.close();}}/*** 发送打印任务至打印机* @param jasperPath* @param parameters* @param list* @throws Exception*/public static void exportToPdfByPrinter(String jasperPath, Map parameters, List<?> list) throws Exception {try {ClassPathResource resource = new ClassPathResource(jasperPath);InputStream jasperStream = resource.getInputStream();JasperPrint jasperPrint = getJasperPrint(jasperStream, parameters, list);PrintRequestAttributeSet pras = new HashPrintRequestAttributeSet();DocFlavor flavor = DocFlavor.BYTE_ARRAY.PNG;PrintService[] printServices = PrintServiceLookup.lookupPrintServices(flavor, pras);for (PrintService printService : printServices) {System.out.println(printService.getName());}//demo默认获取第一个打印机进行打印,实际业务中可以选择所需要的打印机,PrintService printService = printServices[0];JRAbstractExporter je = new JRPrintServiceExporter();je.setParameter(JRExporterParameter.JASPER_PRINT, jasperPrint);//设置指定打印机je.setParameter(JRPrintServiceExporterParameter.PRINT_SERVICE, printService);je.setParameter(JRPrintServiceExporterParameter.DISPLAY_PAGE_DIALOG, false);je.setParameter(JRPrintServiceExporterParameter.DISPLAY_PRINT_DIALOG, false);//打印je.exportReport();jasperStream.close();} catch (Exception e) {log.error("读取报表异常", e);}}public enum ReportType {HTML,PDF,XLS,XLSX,XML,RTF,CSV,DOC}
}
controller
package com.fchan.jasper.controller;import com.fchan.jasper.util.JasperReportUtil;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;import javax.servlet.http.HttpServletResponse;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;@RestController
@RequestMapping("jasper")
public class MyJasperController {@GetMapping("/export")public void getReport(@RequestParam("type") String reportType, HttpServletResponse response)throws Exception {HashMap<String, Object> parameters = new HashMap<String, Object>();parameters.put("name", "xiao ming");List<HashMap> list = new ArrayList<>();for (int i = 0; i < 100; i++) {HashMap<String, String> item = new HashMap<String, String>();item.put("Field1", "Field1-" + i);item.put("Field2", "Field2-" + i);//图片可以填链接item.put("reportDescImage", "https://i.328888.xyz/2023/04/24/iS185a.jpeg");//也可以填写本地图片文件路径//item.put("reportDescImage", "D:\\BaiduNetdiskDownload\\my_huckleberry_friends.jpg");list.add(item);}String jasperPath = JasperReportUtil.getJasperFileDir("demo");if (reportType.equals("pdf")) {JasperReportUtil.exportToPdf(jasperPath, parameters, list, response);} else if (reportType.equals("html")) {JasperReportUtil.exportToHtml(jasperPath, parameters, list, response);}}}
jasper报表模板文件
参考了大佬的博文,在最新的jasper上实践了一遍
https://www.cnblogs.com/xyyz120/p/12681245.html
springboot使用jasper实现报表demo相关推荐
- STS安装配置及写的一个springboot整合mybatis的小demo
新入职的猿,师傅给了一个小任务,用STS写一个springboot整合mybatis的小demo.由于之前没用过STS和eclipse,所以听到这个任务还是比较懵逼的,经过一天的摸索,慢慢的摸出了门道 ...
- Jasper实现报表(Java)
目录 1.TIBCO Jaspersoft Studio安装 2.Jaspersoft Studio使用 2.1 创建一个JasperReports Project 2.2 创建报表模板 2.3 设计 ...
- springboot 集成帆软报表,调用自定义报表 maven创建
帆软作为国内报表开发的NO.1,开发报表方面方便快捷,拖拽式的开发风格非常方便,都不要写后端接口,简单容易上手,是广大开发人员的喜爱选择.空余测试集成,并调用自定义报表,在此分享, 首选,我使用的是e ...
- SpringBoot整合UReport2(报表开发)(配置类版)
文章目录 前言 一.UReport2是什么? 二.使用步骤 1.导入POM 2.添加context.properties 3.编写config配置类 4.访问{ip}{端口}/ureport/desi ...
- jasper report 报表自动生成序号
利用Jasper report 提供的 COLUMN_COUNT函数来生成表格的序号列,在表格分页的时候,序号不能连续,新的一页总是从1开始. 于是,换了一个函数,用REPORT_COUNT,管用,分 ...
- Springboot + Mybatis整合的小demo,火车订票系统
Springboot +Mybatis 的一个订票系统 这学期开了一门软件测试课程,需要做一个系统用于软件测试的学习,就使用目前JavaEE开发中比较火的SpringBoot + Mybatis做了一 ...
- 使用VUE+SpringBoot+EasyExcel 整合导入导出demo
导出示例: 后台: 1.引入依赖:需要引入easyExcel的依赖,但是我在使用过程中发现也是需要poi的依赖,不然会报错,就同时引入了. <dependency><groupId& ...
- java 使用jasper_使用Jasper Reports以Java创建报告
java 使用jasper 上周,我试图使用Jasper创建报告. 在这篇文章中,我将记录一些资源和链接,以便对任何寻求类似信息的人都有用. 我将介绍Jasper报告,示例和Dynamic Jaspe ...
- 使用Jasper Reports以Java创建报告
上周,我试图使用Jasper创建报告. 在这篇文章中,我将记录一些资源和链接,以便对任何寻求类似信息的人都有用. 我将介绍Jasper报告,示例和Dynamic Jasper的生命周期. Jasper ...
最新文章
- 16625篇论文揭示25年来AI进化规律!深度学习时代行将结束!
- 052_Drawer抽屉
- checkbox 选中的id拼接长字符串
- 《从零开始学ASP.NET CORE MVC》课程介绍
- mysql fpmmm_zabbix配fpmmm(mpm)数据传送不了问题解决
- Java应用一般架构
- Java求数组元素的最大和最小值
- JAVA里面pressed的反义词_pressed是什么意思_pressed怎么读_pressed翻译_用法_发音_词组_同反义词_紧缺的-新东方在线英语词典...
- Godot 2D 和 3D 游戏引擎
- SAP系统-WMS Paywall 接口代码-立哥开发
- 数据库原理课后作业答案 第七章
- android中stagefright和OMXCodec原理分析
- rba有哪几個主要組成部分_RBA管理体系有哪些
- AdaBoost 人脸检测介绍(5) : AdaBoost算法的误差界限
- python之“太空大战”小游戏实现
- ATM(异步传输模式)
- 论文笔记——使用信息熵对复杂网络中节点进行影响力排名
- c++switch语言,C++ switch语句
- 【算法学习笔记】6:SAT问题的一些经典求解策略
- 编写程序数一下 1到 100 的所有整数中出现多少次数字9_C语言编写