IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> JasperReport生成PDF报表小节 -> 正文阅读

[开发测试]JasperReport生成PDF报表小节

1、使用Jaspersoft Studio制作PDF模板,生成一个jrxml文件。
在这里插入图片描述

2、编译jrxml文件,生成jasper文件,然后复制到springboot工程中的resources目录下。

3、引入所需依赖

<dependency>
   <groupId>net.sf.jasperreports</groupId>
    <artifactId>jasperreports</artifactId>
    <version>6.19.0</version>
</dependency>

4、创建jasper文件的输入流对象,查询数据库,得到报表所需的数据,填充到PDF里面,然后将PDF文件以字节流的的形式导出到浏览器,实现文件下载,代码如下所示

@SneakyThrows
@GetMapping("/{id}/pdf")
public void pdf(@PathVariable String id, HttpServletResponse response){
    ClassPathResource resource = new ClassPathResource("templates/profile.jasper");
    FileInputStream fis = new FileInputStream(resource.getFile());
    ServletOutputStream sos=null;
    try {
        response.addHeader("Content-Disposition","attachment;filename=employee.pdf");
        sos= response.getOutputStream();
        //员工详情
        UserCompanyPersonal personal = userCompanyPersonalService.getById(id);
        //员工岗位信息
        UserCompanyJobs jobs = userCompanyJobsService.getById(id);
        //员工头像
        String staffPhoto = systemFeignClient.getPhoto(id);
        Map<String,Object> params=new HashMap<>();
        Map<String, Object> personalMap = BeanMapUtils.beanToMap(personal);
        Map<String, Object> jobsMap = BeanMapUtils.beanToMap(jobs);
        params.putAll(personalMap);
        params.putAll(jobsMap);
        params.put("staffPhoto",staffPhoto);
        JasperPrint jasperPrint = JasperFillManager.fillReport(fis, params,new JREmptyDataSource());
        JasperExportManager.exportReportToPdfStream(jasperPrint,sos);
    }finally {
        sos.flush();
        sos.close();
    }
}

其中,params是一个map对象,用来向PDF填充数据,如果先执行

params.put("staffPhoto",staffPhoto);

后执行

params.putAll(personalMap);
params.putAll(jobsMap);

会导致params中的staffPhoto值为空,最终导致PDF导出为空,代码运行报错,而且personalMap和jobsMap里面都不包含staffPhoto这个键。这种现象出现的很奇怪,因为这个错误,卡了我很久,后来通过debug打断点才发现问题所在。

5、JasperReport默认情况下不支持中文,因此会导致PDF中的中文不能显示,解决办法就是在resources中添加fonts.xml、stsong.TTF和jasperreports_extension.properties三个文件,如下所示
在这里插入图片描述其中,stsong.TTF是华文宋体的字体文件,fonts.xml代码如下所示

<?xml version="1.0" encoding="UTF-8"?>

<fontFamilies>

    <!--<fontFamily name="Lobster Two">-->
    <!--<normal>lobstertwo/LobsterTwo-Regular.otf</normal>-->
    <!--<bold>lobstertwo/LobsterTwo-Bold.otf</bold>-->
    <!--<italic>lobstertwo/LobsterTwo-Italic.otf</italic>-->
    <!--<boldItalic>lobstertwo/LobsterTwo-BoldItalic.otf</boldItalic>-->
    <!--<pdfEncoding>Identity-H</pdfEncoding>-->
    <!--<pdfEmbedded>true</pdfEmbedded>-->
    <!--<!–-->
    <!--<exportFonts>-->
    <!--<export key="net.sf.jasperreports.html">'Lobster Two', 'Times New Roman', Times, serif</export>-->
    <!--</exportFonts>-->
    <!--–>-->
    <!--</fontFamily>-->
    <fontFamily name="华文宋体">
        <normal>stsong/stsong.TTF</normal>
        <bold>stsong/stsong.TTF</bold>
        <italic>stsong/stsong.TTF</italic>
        <boldItalic>stsong/stsong.TTF</boldItalic>
        <pdfEncoding>Identity-H</pdfEncoding>
        <pdfEmbedded>true</pdfEmbedded>
        <exportFonts>
            <export key="net.sf.jasperreports.html">'华文宋体', Arial, Helvetica, sans-serif</export>
            <export key="net.sf.jasperreports.xhtml">'华文宋体', Arial, Helvetica, sans-serif</export>
        </exportFonts>
        <!--
        <locales>
            <locale>en_US</locale>
            <locale>de_DE</locale>
        </locales>
        -->
    </fontFamily>
</fontFamilies>

jasperreports_extension.properties代码如下所示

net.sf.jasperreports.extension.registry.factory.simple.font.families=net.sf.jasperreports.engine.fonts.SimpleFontExtensionsRegistryFactory
net.sf.jasperreports.extension.simple.font.families.dejavu=stsong/fonts.xml
  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2022-03-03 16:45:17  更:2022-03-03 16:45:34 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/18 2:53:26-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码