将-HTML-转化为-PDF新姿势

7次阅读

共计 1894 个字符,预计需要花费 5 分钟才能阅读完成。

前篇

使用 Thymeleaf 动态渲染 HTML

1、添加依赖

  <!--PDF 转化工具 -->
        <dependency>
            <groupId>com.itextpdf</groupId>
            <artifactId>itextpdf</artifactId>
            <version>5.4.2</version>
        </dependency>

        <dependency>
            <groupId>org.xhtmlrenderer</groupId>
            <artifactId>core-renderer</artifactId>
            <version>R8</version>
        </dependency>

2、编码工具类


import com.itextpdf.text.pdf.BaseFont;
import com.lowagie.text.DocumentException;
import org.springframework.stereotype.Component;
import org.xhtmlrenderer.pdf.ITextFontResolver;
import org.xhtmlrenderer.pdf.ITextRenderer;

import java.io.IOException;
import java.io.OutputStream;

/**
 * 导出 PDF 文件转换工具
 */
public class PDFUtil{

    /**
     * 生成 PDF 文件
     * @param out 输出流
     * @param html HTML 字符串
     * @throws IOException IO 异常
     * @throws DocumentException Document 异常
     */
    public static void createPDF(OutputStream out, String html) throws IOException, DocumentException {ITextRenderer renderer = new ITextRenderer();
        renderer.setDocumentFromString(html);
        // 解决中文支持问题
        ITextFontResolver fontResolver = renderer.getFontResolver();
        fontResolver.addFont("pdf/font/fangsong.ttf", BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED);
        fontResolver.addFont("pdf/font/PingFangSC.ttf", BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED);
        renderer.layout();
        renderer.createPDF(out);
    }

}

字体文件自行下载,并添加到 resouces 路径下,上述路径对应修改

3、效果演示

遇到的问题与解决方法

1、Maven 打包源码后,导致 HTML 文件内容被篡改

  • 原因:Maven 插件使用的占位符 ${} 与 Thymeleaf 冲突
  • 解决方法:在 pom.xml 中配置资源文件,打包时不对 html 文件的占位符进行处理
<build>
    ...
    <resources>
        <resource>
            <directory>src/main/resources</directory>
            <filtering>true</filtering>
            <excludes>
                <exclude>**/*.html</exclude>
            </excludes>
        </resource>
        <resource>
            <directory>src/main/resources</directory>
            <filtering>false</filtering>
            <includes>
                <include>**/*.html</include>
            </includes>
        </resource>
    </resources>
</build>

2、使用 Docker 制作镜像时,下载文件时报错,缺少字体处理类

  • 使用镜像源 java:8 而不是 openjdk:8-jre-alpine

© 著作权归作者所有, 转载或内容合作请联系作者

● Service Mesh – gRPC 本地联调远程服务

● 使用 Thymeleaf 动态渲染 HTML

● Fastjson 致命缺陷

● Spring Boot 2 集成 log4j2 日志框架

● Java 面试通关要点汇总集之核心篇参考答案

● Java 面试通关要点汇总集之框架篇参考答案

● Spring Security 实战干货:如何保护用户密码

● Spring Boot RabbitMQ – 优先级队列

本文由博客一文多发平台 OpenWrite 发布!

正文完
 0