概述

业务中尝尝需要用到报表数据的渲染和导出.报表的配置势必不能写死,需要动态配置。

现成的JasperReports + Jaspersoft Studio即可实现可配置的报表。

报表布局Jaspersoft Studio

https://community.jaspersoft.com/community-download
下载布局工具,我的pc是win系统,直接下载了exe直接安装了

创建布局项目

  1. File->New->Project先创建一个项目
  2. 然后继续File->New->Jasper Report(也可以直接在demo项目上右键New->Jasper
    Report),选择一个竖向A4纸大小的模板

设计界面展示

  1. Title:标题区,如果数据有多页只会在第一页打印
  2. Page Header:页头区,多页的情况下每页都会打印
  3. Column Header:列头区,配合下面的Detail区打印列表数据,多页的情况下每页都会打印
  4. Detail:可以新增多个Detail区,可以组合打印出多个列表数据,多页的情况下每页都会打印
  5. Column Footer:列表底部区,多页的情况下每页都会打印
  6. Page Footer:页底部区,多页的情况下每页都会打印
  7. Summary:合计区,只会在最后一页打印

创建完项目后–报表demo

  1. 从右侧Basic Elements区域拖拽一个Static Text元素到Title区,选中元素后,可以在右侧设置元素的边框,字体和大小,文本的对齐方式等等。
  2. 在左侧Outline区域Paramters上右键Create Paramter创建一个新的属性,命名为name,类型java.lang.String
  3. 拖拽name属性到Page Header区域,同样可以在右侧设置它的属性
  4. 在左侧Outline区域Fields上右键 Create Field创建两个字段Field1,Field2,类型java.lang.String
  5. 然后拖拽Field1,Field2字段到Detail1区域,会自动带出两个值为Field1,Field2Static Text元素在Column Header区域,调整位置对齐
  6. 右键jrxml文件可以预览看看样式,因为此时我们未给Field1,Field2的数据集赋值,所以预览的为null
  7. 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相关推荐

  1. STS安装配置及写的一个springboot整合mybatis的小demo

    新入职的猿,师傅给了一个小任务,用STS写一个springboot整合mybatis的小demo.由于之前没用过STS和eclipse,所以听到这个任务还是比较懵逼的,经过一天的摸索,慢慢的摸出了门道 ...

  2. Jasper实现报表(Java)

    目录 1.TIBCO Jaspersoft Studio安装 2.Jaspersoft Studio使用 2.1 创建一个JasperReports Project 2.2 创建报表模板 2.3 设计 ...

  3. springboot 集成帆软报表,调用自定义报表 maven创建

    帆软作为国内报表开发的NO.1,开发报表方面方便快捷,拖拽式的开发风格非常方便,都不要写后端接口,简单容易上手,是广大开发人员的喜爱选择.空余测试集成,并调用自定义报表,在此分享, 首选,我使用的是e ...

  4. SpringBoot整合UReport2(报表开发)(配置类版)

    文章目录 前言 一.UReport2是什么? 二.使用步骤 1.导入POM 2.添加context.properties 3.编写config配置类 4.访问{ip}{端口}/ureport/desi ...

  5. jasper report 报表自动生成序号

    利用Jasper report 提供的 COLUMN_COUNT函数来生成表格的序号列,在表格分页的时候,序号不能连续,新的一页总是从1开始. 于是,换了一个函数,用REPORT_COUNT,管用,分 ...

  6. Springboot + Mybatis整合的小demo,火车订票系统

    Springboot +Mybatis 的一个订票系统 这学期开了一门软件测试课程,需要做一个系统用于软件测试的学习,就使用目前JavaEE开发中比较火的SpringBoot + Mybatis做了一 ...

  7. 使用VUE+SpringBoot+EasyExcel 整合导入导出demo

    导出示例: 后台: 1.引入依赖:需要引入easyExcel的依赖,但是我在使用过程中发现也是需要poi的依赖,不然会报错,就同时引入了. <dependency><groupId& ...

  8. java 使用jasper_使用Jasper Reports以Java创建报告

    java 使用jasper 上周,我试图使用Jasper创建报告. 在这篇文章中,我将记录一些资源和链接,以便对任何寻求类似信息的人都有用. 我将介绍Jasper报告,示例和Dynamic Jaspe ...

  9. 使用Jasper Reports以Java创建报告

    上周,我试图使用Jasper创建报告. 在这篇文章中,我将记录一些资源和链接,以便对任何寻求类似信息的人都有用. 我将介绍Jasper报告,示例和Dynamic Jasper的生命周期. Jasper ...

最新文章

  1. 16625篇论文揭示25年来AI进化规律!深度学习时代行将结束!
  2. 052_Drawer抽屉
  3. checkbox 选中的id拼接长字符串
  4. 《从零开始学ASP.NET CORE MVC》课程介绍
  5. mysql fpmmm_zabbix配fpmmm(mpm)数据传送不了问题解决
  6. Java应用一般架构
  7. Java求数组元素的最大和最小值
  8. JAVA里面pressed的反义词_pressed是什么意思_pressed怎么读_pressed翻译_用法_发音_词组_同反义词_紧缺的-新东方在线英语词典...
  9. Godot 2D 和 3D 游戏引擎
  10. SAP系统-WMS Paywall 接口代码-立哥开发
  11. 数据库原理课后作业答案 第七章
  12. android中stagefright和OMXCodec原理分析
  13. rba有哪几個主要組成部分_RBA管理体系有哪些
  14. AdaBoost 人脸检测介绍(5) : AdaBoost算法的误差界限
  15. python之“太空大战”小游戏实现
  16. ATM(异步传输模式)
  17. 论文笔记——使用信息熵对复杂网络中节点进行影响力排名
  18. c++switch语言,C++ switch语句
  19. 【算法学习笔记】6:SAT问题的一些经典求解策略
  20. 编写程序数一下 1到 100 的所有整数中出现多少次数字9_C语言编写

热门文章

  1. 求职招聘系统开发(APP、小程序、公众号)
  2. 个人博客-7(网站首页制作)
  3. surfaceview 和surfaceholder的理解和使用
  4. 前端学习-AJAX练习(天气预报/周公解梦/汇率查询)
  5. 记账的艺术 — 彻底搞懂会计的借贷法则
  6. 【220221】838.推多米诺
  7. 【以太网硬件十六】双绞线有哪些种类?
  8. ZigBee组网原理
  9. 名片打印也可以私人订制 高附加值打印方案新选
  10. oracle中的iw和ww学习