java - 使用具有动态页眉和页脚的 itext7 将 HTML 模板转换为 PDF

标签 java html css pdf itext7

我尝试使用下面的 HTML 模板使用 iText7 将其转换为 PDF,但页眉和页脚都没有绑定(bind)到其预期位置。 used example 我试图避免 @Page 页眉和页脚属性,因为我试图在两个部分中完成动态内容的适配,每个部分的扩展空间超过 3 行。

iText 代码和结果:

ConverterProperties properties = new ConverterProperties();
//properties.setFontProvider(fontProvider);
properties.setMediaDeviceDescription(new MediaDeviceDescription(MediaType.PRINT));
PdfWriter writer = new PdfWriter("out.pdf");
PdfDocument pdf = new PdfDocument(writer);
pdf.setTagged();
PageSize pageSize = PageSize.LETTER;
pdf.setDefaultPageSize(pageSize);

OutlineHandler outlineHandler = OutlineHandler.createStandardHandler();
properties.setOutlineHandler(outlineHandler);

//html template (templateOutput)
HtmlConverter.convertToPdf(templateOutput, pdf, properties);
byte[] pdfData = byteArrayOutputStream.toByteArray();
pdf.close();

The second page without header and footer First Page

请问有什么建议可以解决这个问题吗? 谢谢

最佳答案

以下是由 pdfHTML 正确处理的 HTML 示例,并且多行标题按预期完全显示在页面顶部:

<!DOCTYPE html>
<html>

<head>
    <style>
        #header {
            position: running(header);
        }

        @page {
            margin-top: 100px;
            @top-center {
                content: element(header);
            }
        }
    </style>
</head>

<body>

<div id="header">Header line 1<br/>Header line 2<br/>Header line 3</div>

<p>Content of the page</p>

</body>
</html>

页面在生成的 PDF 中如下所示:

result

关于java - 使用具有动态页眉和页脚的 itext7 将 HTML 模板转换为 PDF,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60827977/

相关文章:

c# - <% %> <--这叫什么?我如何在其中编写 C# 代码

javascript - 切换多个 jQuery 图标

html - 图像映射背景图像?

css - Pagespeed 警告 - 在图像元素上使用明确的宽度和高度

java - 无法通过 Eclipse Kepler 启动 Tomcat 7

javascript - Java 8 Lambda 构造和 JavaScript 之间的确切区别是什么?

java - 无法加载 JDBC 驱动程序类

java - java中的散列json

html - 如何在 div 的中心左对齐文本?

html - 如何让两个元素共享一个框阴影