Java实现PDF模板动态赋值与文档生成的多种方式

 更新时间:2025年07月10日 10:38:57   作者:自由的疯  
除了 iText 库,在 Java 中还有其他一些库可以用于处理 PDF 模板并进行动态赋值,这篇文章就来为大家详细介绍几种常见的库及其使用示例吧

1. Apache PDFBox

Apache PDFBox 是一个开源的 Java 库,可用于创建、操作和提取 PDF 文档中的内容。它提供了丰富的 API 来处理 PDF 表单,能够实现从 PDF 模板生成新文档并动态赋值的功能。

添加依赖

如果你使用 Maven 项目,在 ​​pom.xml​​ 中添加以下依赖:

<dependency>
    <groupId>org.apache.pdfbox</groupId>
    <artifactId>pdfbox</artifactId>
    <version>3.0.0</version>
</dependency>

示例代码

import org.apache.pdfbox.pdmodel.PDDocument;
import org.apache.pdfbox.pdmodel.PDPage;
import org.apache.pdfbox.pdmodel.interactive.form.PDAcroForm;
import org.apache.pdfbox.pdmodel.interactive.form.PDField;

import java.io.File;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

public class PdfBoxTemplateGenerator {

    public static void main(String[] args) {
        String templatePath = "template.pdf";
        String outputPath = "output.pdf";
        Map<String, String> values = new HashMap<>();
        values.put("name", "李四");
        values.put("age", "30");

        try {
            generatePdfFromTemplate(templatePath, outputPath, values);
            System.out.println("PDF 文档生成成功,路径为: " + outputPath);
        } catch (IOException e) {
            System.err.println("生成 PDF 文档时出现错误: " + e.getMessage());
            e.printStackTrace();
        }
    }

    public static void generatePdfFromTemplate(String templatePath, String outputPath, Map<String, String> values) throws IOException {
        // 加载 PDF 模板文档
        try (PDDocument document = PDDocument.load(new File(templatePath))) {
            // 获取文档中的表单
            PDAcroForm acroForm = document.getDocumentCatalog().getAcroForm();
            if (acroForm != null) {
                // 遍历动态赋值的键值对
                for (Map.Entry<String, String> entry : values.entrySet()) {
                    // 获取表单字段
                    PDField field = acroForm.getField(entry.getKey());
                    if (field != null) {
                        // 设置字段的值
                        field.setValue(entry.getValue());
                    }
                }
            }

            // 保存修改后的文档
            document.save(outputPath);
        }
    }
}

代码解释

  • ​PDDocument.load​​:用于加载 PDF 模板文件。
  • ​document.getDocumentCatalog().getAcroForm()​​:获取 PDF 文档中的表单。
  • ​acroForm.getField​​:通过字段名称获取表单字段。
  • ​field.setValue​​:设置表单字段的值。
  • ​document.save​​:保存修改后的文档。

2. Flying Saucer

Flying Saucer 是一个用于将 HTML/CSS 转换为 PDF 的 Java 库。你可以先创建 HTML 模板,然后将其转换为 PDF 文档,并在 HTML 中使用占位符进行动态赋值。

添加依赖

如果你使用 Maven 项目,在 ​​pom.xml​​ 中添加以下依赖:

<dependency>
    <groupId>org.xhtmlrenderer</groupId>
    <artifactId>flying-saucer-pdf-itext5</artifactId>
    <version>9.1.22</version>
</dependency>

示例代码

import org.xhtmlrenderer.pdf.ITextRenderer;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.util.HashMap;
import java.util.Map;

public class FlyingSaucerTemplateGenerator {

    public static void main(String[] args) {
        String templatePath = "template.html";
        String outputPath = "output.pdf";
        Map<String, String> values = new HashMap<>();
        values.put("${name}", "王五");
        values.put("${age}", "35");

        try {
            generatePdfFromTemplate(templatePath, outputPath, values);
            System.out.println("PDF 文档生成成功,路径为: " + outputPath);
        } catch (Exception e) {
            System.err.println("生成 PDF 文档时出现错误: " + e.getMessage());
            e.printStackTrace();
        }
    }

    public static void generatePdfFromTemplate(String templatePath, String outputPath, Map<String, String> values) throws Exception {
        // 读取 HTML 模板文件内容
        String htmlContent = new String(Files.readAllBytes(Paths.get(templatePath)));

        // 替换 HTML 中的占位符
        for (Map.Entry<String, String> entry : values.entrySet()) {
            htmlContent = htmlContent.replace(entry.getKey(), entry.getValue());
        }

        // 创建输出流
        try (OutputStream outputStream = new FileOutputStream(new File(outputPath))) {
            // 创建 ITextRenderer 对象
            ITextRenderer renderer = new ITextRenderer();
            // 设置 HTML 内容
            renderer.setDocumentFromString(htmlContent);
            // 布局渲染
            renderer.layout();
            // 生成 PDF
            renderer.createPDF(outputStream);
        }
    }
}

代码解释

  • ​Files.readAllBytes​​:读取 HTML 模板文件的内容。
  • ​htmlContent.replace​​:替换 HTML 中的占位符。
  • ​ITextRenderer.setDocumentFromString​​:设置 HTML 内容。
  • ​renderer.layout​​:进行布局渲染。
  • ​renderer.createPDF​​:生成 PDF 文档。

各库的优缺点比较

库名称优点缺点
iText功能强大,支持复杂的 PDF 操作,有丰富的文档和社区支持部分高级功能需要付费许可证
Apache PDFBox开源免费,易于使用,适合处理简单的 PDF 表单对于复杂的 PDF 布局处理能力相对较弱
Flying Saucer可以利用 HTML/CSS 的优势进行模板设计,灵活性高性能相对较低,对于复杂的 PDF 效果实现可能有一定难度

到此这篇关于Java实现PDF模板动态赋值与文档生成的多种方式的文章就介绍到这了,更多相关Java PDF模板动态赋值内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java-ElementUi中的row-class-name使用

    Java-ElementUi中的row-class-name使用

    这篇文章主要介绍了Java-ElementUi中的row-class-name使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • Java Optional解决空指针异常总结(java 8 功能)

    Java Optional解决空指针异常总结(java 8 功能)

    这篇文章主要介绍了Java Optional解决空指针异常总结(java 8 功能),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • Java动态规划之硬币找零问题实现示例

    Java动态规划之硬币找零问题实现示例

    本文主要介绍了Java动态规划之硬币找零问题实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08
  • 通过JDBC连接oracle数据库的十大技巧

    通过JDBC连接oracle数据库的十大技巧

    通过JDBC连接oracle数据库的十大技巧...
    2006-12-12
  • CommonMark 使用教程:将 Markdown 语法转成 Html

    CommonMark 使用教程:将 Markdown 语法转成 Html

    这篇文章主要介绍了CommonMark 使用教程:将 Markdown 语法转成 Html,这个技巧我们做任何网站都可以用到,而且非常好用。,需要的朋友可以参考下
    2019-06-06
  • 详解Java中雪花算法的实现

    详解Java中雪花算法的实现

    雪花算法是一种分布式的id生成算法。原理是将long分成若干个区段分别管理。本文将利用Java简单的实现雪花算法,感兴趣的可以了解一下
    2022-12-12
  • mybatis-plus如何配置自定义数据类型TypeHandle

    mybatis-plus如何配置自定义数据类型TypeHandle

    这篇文章主要介绍了mybatis-plus如何配置自定义数据类型TypeHandle,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01
  • 解析Java中的Field类和Method类

    解析Java中的Field类和Method类

    这篇文章主要介绍了Java中的Field类和Method类,是Java入门学习中的基础知识,需要的朋友可以参考下
    2015-12-12
  • Java Socket编程详解及示例代码

    Java Socket编程详解及示例代码

    本文主要讲解Java Socket编程,这里整理了详细的技术资料及简单的示例代码帮助大家学习参考,有需要的小伙伴可以参考下本文内容
    2016-09-09
  • Java设计模式中的抽象工厂模式解读

    Java设计模式中的抽象工厂模式解读

    这篇文章主要介绍了Java设计模式中的抽象工厂模式解读,抽象工厂模式为创建一组相关或相互依赖的对象提供一个接口,而且无需指定他们的具体类,需要的朋友可以参考下
    2023-11-11

最新评论