当前位置: 首页 > article >正文

SpringBoot集成JasperReports实现PDF、HTML、XML的一键生成

JasperReports 是一个基于 Java 的开源报表工具支持多种输出格式如 PDF、HTML、XML 等广泛应用于 Java 开发中生成动态报表‌。本文将完整演示如何在 Spring Boot 项目中整合 JasperReports从环境配置、模板设计到接口开发逐步实现用户数据报表的导出。核心原理‌工作流程‌‌JRXML‌XML 格式的报表模板文件通过设计器如 Jaspersoft Studio创建‌。‌Jasper‌编译 JRXML 生成的二进制文件用于数据填充‌。‌Jrprint‌填充数据后的报表对象最终通过导出器生成目标格式文件‌。‌技术特点‌支持多种数据源JDBC、JavaBeans、XML 等‌。可生成带水印的报表和子报表。集成JasperReports步骤项目目录结构引入依赖在pom.xml中添加 JasperReports 相关依赖12345678910111213141516171819202122232425262728293031dependencies!-- JasperReports 核心依赖 --dependencygroupIdnet.sf.jasperreports/groupIdartifactIdjasperreports/artifactIdversion7.0.3/version/dependency!-- JasperReports PDF 支持 --dependencygroupIdnet.sf.jasperreports/groupIdartifactIdjasperreports-pdf/artifactIdversion7.0.3/version/dependency!-- Spring Boot Web --dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-web/artifactId/dependency!-- Lombok 简化实体类代码 --dependencygroupIdorg.projectlombok/groupIdartifactIdlombok/artifactIdoptionaltrue/optional/dependency/dependencies核心代码实现启动类12345678910111213packagecom.icoderoad;importorg.springframework.boot.SpringApplication;importorg.springframework.boot.autoconfigure.SpringBootApplication;SpringBootApplicationpublicclassSpringbootJasperreportApplication {publicstaticvoidmain(String[] args) {SpringApplication.run(SpringbootJasperreportApplication.class, args);}}User 实体类123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263packagecom.icoderoad.entity;publicclassUser {privateLong id;privateString name;privateInteger age;privateString email;privateString address;publicUser(Long id, String name, Integer age, String email, String address) {this.id id;this.name name;this.age age;this.email email;this.address address;}publicUser() {}// Getter 和 SetterpublicLong getId() {returnid;}publicvoidsetId(Long id) {this.id id;}publicString getName() {returnname;}publicvoidsetName(String name) {this.name name;}publicInteger getAge() {returnage;}publicvoidsetAge(Integer age) {this.age age;}publicString getEmail() {returnemail;}publicvoidsetEmail(String email) {this.email email;}publicString getAddress() {returnaddress;}publicvoidsetAddress(String address) {this.address address;}}报表生成工具类123456789101112131415161718192021222324252627282930313233343536373839404142434445packagecom.icoderoad.report;importcom.icoderoad.entity.User;importnet.sf.jasperreports.engine.*;importnet.sf.jasperreports.engine.data.JRBeanCollectionDataSource;importorg.springframework.core.io.ClassPathResource;importjava.nio.file.Files;importjava.nio.file.Paths;importjava.util.*;publicclassReportGenerator {publicstaticbyte[] generate(ListUser users, String format)throwsException {// 1. 加载并编译报表模板ClassPathResource resource newClassPathResource(templates/user.jrxml);JasperReport jasperReport JasperCompileManager.compileReport(resource.getInputStream());// 2. 准备数据源和参数JRBeanCollectionDataSource dataSource newJRBeanCollectionDataSource(users);MapString, Object parameters newHashMap();parameters.put(title,用户列表);JasperPrint jasperPrint JasperFillManager.fillReport(jasperReport, parameters, dataSource);// 3. 导出不同格式returnswitch(format) {casepdf- JasperExportManager.exportReportToPdf(jasperPrint);casexml- JasperExportManager.exportReportToXml(jasperPrint).getBytes();casehtml- {String path /tmp/user.html;JasperExportManager.exportReportToHtmlFile(jasperPrint, path);yield Files.readAllBytes(Paths.get(path));}default-thrownewIllegalArgumentException(不支持的格式: format);};}}控制层1234567891011121314151617181920212223242526272829303132333435363738394041424344packagecom.icoderoad.controller;importcom.icoderoad.entity.User;importcom.icoderoad.report.ReportGenerator;importorg.springframework.core.io.ByteArrayResource;importorg.springframework.core.io.Resource;importorg.springframework.http.*;importorg.springframework.web.bind.annotation.*;importjava.util.*;RestControllerRequestMapping(/users)publicclassReportController {GetMapping(/export/{format})publicResponseEntityResource export(PathVariableString format)throwsException {// 模拟数据ListUser users newArrayList();for(inti 0; i 10; i) {users.add(newUser((long) i,姓名- i,newRandom().nextInt(100),i qq.com,地址- i));}// 生成报表byte[] content ReportGenerator.generate(users, format);ByteArrayResource resource newByteArrayResource(content);returnResponseEntity.ok().contentType(MediaType.APPLICATION_OCTET_STREAM).header(HttpHeaders.CONTENT_DISPOSITION,ContentDisposition.attachment().filename(user-report. format).build().toString()).contentLength(resource.contentLength()).body(resource);}}配置文件12345server:port:8080spring:application:name: springboot-jasperreport-demojasperreports.properties12net.sf.jasperreports.extension.registry.factory.simple.font.familiesnet.sf.jasperreports.engine.fonts.SimpleFontExtensionsRegistryFactorynet.sf.jasperreports.extension.simple.font.families.simheifonts/fonts.xml首先在 Linux 系统中将 Windows 的黑体字体文件simhei.ttf拷贝到项目目录1src/main/resources/fonts/simhei.ttf1fonts/fonts.xml123456789101112131415?xml versinotallow1.0encodingUTF-8?fontFamiliesfontFamily name黑体normalfonts/simhei.ttf/normalboldfonts/simhei.ttf/bolditalicfonts/simhei.ttf/italicboldItalicfonts/simhei.ttf/boldItalicpdfEncodingIdentity-H/pdfEncodingpdfEmbeddedtrue/pdfEmbeddedexportFontsexport keynet.sf.jasperreports.html黑体, Arial, Helvetica, sans-serif/exportexport keynet.sf.jasperreports.xhtml黑体, Arial, Helvetica, sans-serif/export/exportFonts/fontFamily/fontFamiliesuser.jrxml 示例模板12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061?xml versinotallow1.0encodingUTF-8?!-- 用户列表报表模板 --jasperReport xmlnshttp://jasperreports.sourceforge.net/jasperreportsxmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://jasperreports.sourceforge.net/jasperreportshttp://jasperreports.sourceforge.net/xsd/jasperreport.xsdnameuser_reportpageWidth595pageHeight842columnWidth555leftMargin20rightMargin20topMargin20bottomMargin20uuid123e4567-e89b-12d3-a456-426614174000!-- 报表参数 --parameter nametitleclassjava.lang.String/!-- 字段定义 --field nameidclassjava.lang.Long/field namenameclassjava.lang.String/field nameageclassjava.lang.Integer/field nameemailclassjava.lang.String/field nameaddressclassjava.lang.String/!-- 报表标题 --titleband height50staticTextreportElement x0y10width555height30/textElement textAlignmentCenterfont fontName黑体size16isBoldtrue//textElementtext![CDATA[$P{title}]]/text/staticText/band/title!-- 表头 --columnHeaderband height20staticTextreportElement x0y0width50height20/text![CDATA[ID]]/text/staticTextstaticTextreportElement x50y0width100height20/text![CDATA[姓名]]/text/staticTextstaticTextreportElement x150y0width50height20/text![CDATA[年龄]]/text/staticTextstaticTextreportElement x200y0width150height20/text![CDATA[邮箱]]/text/staticTextstaticTextreportElement x350y0width205height20/text![CDATA[地址]]/text/staticText/band/columnHeader!-- 数据体 --detailband height20textFieldreportElement x0y0width50height20/textFieldExpression![CDATA[$F{id}]]/textFieldExpression/textFieldtextFieldreportElement x50y0width100height20/textFieldExpression![CDATA[$F{name}]]/textFieldExpression/textFieldtextFieldreportElement x150y0width50height20/textFieldExpression![CDATA[$F{age}]]/textFieldExpression/textFieldtextFieldreportElement x200y0width150height20/textFieldExpression![CDATA[$F{email}]]/textFieldExpression/textFieldtextFieldreportElement x350y0width205height20/textFieldExpression![CDATA[$F{address}]]/textFieldExpression/textField/band/detail/jasperReport测试接口启动服务后分别访问以下地址即可获取不同格式的报表PDF 报表http://localhost:8080/users/export/pdfXML 报表http://localhost:8080/users/export/xmlHTML 报表http://localhost:8080/users/export/html结论通过本文的实践我们基于Spring Boot JasperReports搭建了一套完整的报表生成解决方案实现了PDF、HTML、XML的多格式一键导出。整个过程涵盖了依赖引入、字体配置、模板设计、数据填充、接口实现等关键环节。

相关文章:

SpringBoot集成JasperReports实现PDF、HTML、XML的一键生成

JasperReports 是一个基于 Java 的开源报表工具,支持多种输出格式(如 PDF、HTML、XML 等),广泛应用于 Java 开发中生成动态报表‌。本文将完整演示如何在 Spring Boot 项目中整合 JasperReports,从环境配置、模板设计到…...

面试技巧提升:系统设计问题的高分回答框架

面试技巧提升:系统设计问题的高分回答框架 在技术面试中,系统设计问题往往是区分候选人的关键环节。无论是初级工程师还是资深架构师,能否清晰、系统地回答这类问题,直接决定了面试的成败。许多人在面对开放性的系统设计问题时容…...

多智能体系统的一致性维护:处理冲突、达成共识的算法与实践

多智能体系统的一致性维护:处理冲突、达成共识的算法与实践 1. 核心概念 多智能体系统(Multi-Agent System, MAS)是人工智能和分布式系统领域的重要研究方向,它由多个自主或半自主的智能体组成,这些智能体通过相互协作、竞争或协商来解决单个智能体无法或难以解决的问题…...

多模态大模型端侧落地难?揭秘TensorRT-LLM+ONNX Runtime双引擎协同部署的7个关键阈值指标

第一章:多模态大模型端侧部署方案 2026奇点智能技术大会(https://ml-summit.org) 端侧部署多模态大模型面临算力受限、内存紧张、功耗敏感与实时性要求高等多重挑战。当前主流路径聚焦于模型轻量化、推理引擎适配与硬件协同优化三大方向,兼顾语义理解、…...

5分钟搞定!Ollama部署DeepSeek-R1推理模型,小白也能用的AI解题工具

5分钟搞定!Ollama部署DeepSeek-R1推理模型,小白也能用的AI解题工具 1. 引言:为什么选择DeepSeek-R1-Distill-Qwen-7B 你是否遇到过复杂的数学题解不出来?或者需要快速生成专业报告却无从下手?DeepSeek-R1-Distill-Qw…...

SillyTavern角色系统深度解析:构建沉浸式AI交互体验的技术架构与实践

SillyTavern角色系统深度解析:构建沉浸式AI交互体验的技术架构与实践 【免费下载链接】SillyTavern LLM Frontend for Power Users. 项目地址: https://gitcode.com/GitHub_Trending/si/SillyTavern SillyTavern作为面向高级用户的LLM前端工具,其…...

Windows Subsystem for Android 终极指南:在 Windows 11 上无缝运行 Android 应用

Windows Subsystem for Android 终极指南:在 Windows 11 上无缝运行 Android 应用 【免费下载链接】WSA Developer-related issues and feature requests for Windows Subsystem for Android 项目地址: https://gitcode.com/gh_mirrors/ws/WSA 想在 Windows …...

从零开始的大数据之路(6)- 三分钟安装部署好Datax

目录 datax的安装包: 从零开始的大数据之路 (0)的葵花宝典 -- 安装包分享 -- 错过就是罪过 [持续更新分享]-CSDN博客 1、上传datax安装包到服务器并分发到其他服务器 2、解压Datax 3、测试Datax 4、测试失败 datax报错解决 解决 再次…...

大模型---ReAct

目录 1.ReAct的定义 2.ReAct的基本形式 3.ReAct与普通CoT、Toolformer的区别 4.ReAct与Plan-and-Solve 5.ReAct的局限 深入学习会继续补充~ 1.ReAct的定义 ReAct是Agent编排(Orchestration)的逻辑循环(Reasoning Loop)中最经典的实现方式,编排是Agent的“神经…...

5分钟快速解密网易云音乐NCM格式:免费工具实现音乐自由播放

5分钟快速解密网易云音乐NCM格式:免费工具实现音乐自由播放 【免费下载链接】ncmdump 项目地址: https://gitcode.com/gh_mirrors/ncmd/ncmdump 还在为网易云音乐下载的NCM格式文件无法在其他播放器使用而烦恼吗?ncmdump是一款高效便捷的NCM格式…...

海康工业相机C语言SDK实战:从零配置一个完整的视觉采集程序(附完整代码)

海康工业相机C语言SDK实战:从零构建视觉采集系统的完整指南 工业视觉系统在现代制造业中扮演着越来越重要的角色,而相机作为系统的"眼睛",其稳定高效的采集能力直接影响整个系统的性能。本文将带您从零开始,使用海康工业…...

从STM32 HAL库转战逐飞TC264:GPIO配置的5个关键差异与实战避坑指南

从STM32 HAL库转战逐飞TC264:GPIO配置的5个关键差异与实战避坑指南 如果你已经习惯了STM32 HAL库的开发方式,初次接触逐飞TC264的GPIO配置可能会感到既熟悉又陌生。就像从自动挡汽车换到手动挡,虽然都是驾驶,但操作逻辑和细节处理…...

香橙派5Plus内核编译踩坑实录:从WSL报错到板端编译卡死的完整解决方案

香橙派5Plus内核编译实战:破解WSL兼容性与板端卡死难题 当我在工作室里第一次点亮香橙派5Plus时,这块搭载Rockchip RK3588的开发板立刻吸引了我的注意。作为一款性能强劲的ARM开发平台,它本应成为嵌入式开发的理想选择——直到我尝试为其编译…...

PMD大数据处理终极指南:如何高效分析TB级代码仓库的10个技巧

PMD大数据处理终极指南:如何高效分析TB级代码仓库的10个技巧 【免费下载链接】pmd An extensible multilanguage static code analyzer. 项目地址: https://gitcode.com/gh_mirrors/pm/pmd PMD作为一款可扩展的多语言静态代码分析工具,能够帮助开…...

终极指南:PointNet激活函数性能大比拼 ReLU、LeakyReLU与Swish深度测试

终极指南:PointNet激活函数性能大比拼 ReLU、LeakyReLU与Swish深度测试 【免费下载链接】pointnet PointNet: Deep Learning on Point Sets for 3D Classification and Segmentation 项目地址: https://gitcode.com/gh_mirrors/po/pointnet PointNet作为3D点…...

3个致命对比:C# vs Python,谁才是真“香“?

🔥关注墨瑾轩,带你探索编程的奥秘!🚀 🔥超萌技术攻略,轻松晋级编程高手🚀 🔥技术宝库已备好,就等你来挖掘🚀 🔥订阅墨瑾轩,智趣学习不…...

5个关键步骤:C# OpenCVSharp如何让背景分割快10倍?

🔥关注墨瑾轩,带你探索编程的奥秘!🚀 🔥超萌技术攻略,轻松晋级编程高手🚀 🔥技术宝库已备好,就等你来挖掘🚀 🔥订阅墨瑾轩,智趣学习不…...

如何快速构建电商库存扫描系统:QuaggaJS条形码识别终极指南

如何快速构建电商库存扫描系统:QuaggaJS条形码识别终极指南 【免费下载链接】quaggaJS An advanced barcode-scanner written in JavaScript 项目地址: https://gitcode.com/gh_mirrors/qu/quaggaJS 在电商运营中,高效的库存管理是提升效率和降低…...

终极指南:用Universal x86 Tuning Utility轻松解锁AMD/Intel处理器潜能

终极指南:用Universal x86 Tuning Utility轻松解锁AMD/Intel处理器潜能 【免费下载链接】Universal-x86-Tuning-Utility Unlock the full potential of your Intel/AMD based device. 项目地址: https://gitcode.com/gh_mirrors/un/Universal-x86-Tuning-Utility …...

Apollo Client 终极指南:从零构建宝可梦图鉴应用的完整教程

Apollo Client 终极指南:从零构建宝可梦图鉴应用的完整教程 【免费下载链接】learnapollo 👩🏻‍🏫 Learn Apollo - A hands-on tutorial for Apollo GraphQL Client (created by Graphcool) 项目地址: https://gitcode.com/gh_…...

Ollama+Llama-3.2-3B实战:快速搭建本地写作助手,帮你写邮件、周报、文案

OllamaLlama-3.2-3B实战:快速搭建本地写作助手,帮你写邮件、周报、文案 1. 告别“憋稿子”,让AI成为你的专属写作秘书 你有没有过这样的经历?周五下午,对着空白的Word文档,绞尽脑汁想周报怎么写&#xff…...

10个jQuery Form性能监控技巧:如何精确测量表单提交性能指标

10个jQuery Form性能监控技巧:如何精确测量表单提交性能指标 【免费下载链接】form jQuery Form Plugin 项目地址: https://gitcode.com/gh_mirrors/fo/form jQuery Form Plugin(src/jquery.form.js)是一款轻量级的表单处理工具&#…...

数据库运维工具

数据库运维工具:高效管理的智能助手 在数据驱动的时代,数据库作为企业核心信息的存储载体,其稳定性与性能直接影响业务运行。随着数据量激增和架构复杂化,传统人工运维已难以满足需求。数据库运维工具应运而生,通过自…...

GLM-4-9B-Chat-1M效果展示:100万token下跨章节逻辑推理能力实测

GLM-4-9B-Chat-1M效果展示:100万token下跨章节逻辑推理能力实测 1. 引言:当大模型遇上“超长待机” 想象一下,你手里有一本300页的小说,或者一个包含几十个文件的代码项目。你想让AI帮你分析整个故事的情节脉络,或者…...

Teldrive代码架构解析:从cmd到pkg的完整项目结构

Teldrive代码架构解析:从cmd到pkg的完整项目结构 【免费下载链接】teldrive Teldrive 项目地址: https://gitcode.com/gh_mirrors/te/teldrive Teldrive是一个功能强大的文件管理系统,它允许用户通过直观的界面管理、预览和分享各种类型的文件。本…...

FlowLayout在实际项目中的应用:从标签云到动态表单的完整实现

FlowLayout在实际项目中的应用:从标签云到动态表单的完整实现 【免费下载链接】FlowLayout A flow layout for Android with auto-spacing. 项目地址: https://gitcode.com/gh_mirrors/flo/FlowLayout FlowLayout是一款专为Android平台设计的流式布局库&…...

AppScale GTS核心组件深度解析:从数据存储到任务队列

AppScale GTS核心组件深度解析:从数据存储到任务队列 【免费下载链接】gts AppScale is an easy-to-manage serverless platform for building and running scalable web and mobile applications on any infrastructure. 项目地址: https://gitcode.com/gh_mirro…...

3步解决NVIDIA Profile Inspector配置难题:从诊断到修复的完整指南

3步解决NVIDIA Profile Inspector配置难题:从诊断到修复的完整指南 【免费下载链接】nvidiaProfileInspector 项目地址: https://gitcode.com/gh_mirrors/nv/nvidiaProfileInspector NVIDIA Profile Inspector作为一款强大的显卡配置管理工具,允…...

故障排查手册从现象到根因分析

故障排查手册:从现象到根因的精准拆解 在复杂的系统运维或设备维护中,故障往往像一场突如其来的风暴,而一本结构化的故障排查手册就是工程师的“导航仪”。它通过从表面现象逐层深入,最终锁定根因,不仅能快速恢复系统…...

Qwen3智能字幕系统入门必看:从零部署清音刻墨镜像详细步骤

Qwen3智能字幕系统入门必看:从零部署清音刻墨镜像详细步骤 你是不是也遇到过这样的烦恼?自己录制的视频,或者下载的课程,想配上精准的字幕,结果发现自动生成的字幕时间轴对不上,要么字幕提前了&#xff0c…...