gpt4 book ai didi

java - 将 PDF 与 iText 合并会导致关闭时出现 "Do you want to save changes...?"对话框

转载 作者:行者123 更新时间:2023-12-01 15:00:13 25 4
gpt4 key购买 nike

我在这里看到了关于这个问题的类似问题,尽管主要是在 C#/iTextSharp 的上下文中。

我有以下 Java 方法:

public byte[] prependCoversheet(byte[] pdfBytes)
{
InputStream pdfTemplate = getClass().getResourceAsStream("coversheet.pdf");
PdfReader reader = new PdfReader(pdfTemplate);
ByteArrayOutputStream baos1 = new ByteArrayOutputStream();
ByteArrayOutputStream baos2 = new ByteArrayOutputStream();

PdfCopyFields copy = new PdfCopyFields(baos1);
PdfStamper stamper = new PdfStamper(reader, baos2);

AcroFields coversheet = stamper.getAcroFields();

/* Set all the field values here, etc. */
coversheet.setField("fieldName", "Lorem ipsum dolor sit amet.");

stamper.setFormFlattening(true);
stamper.close();

copy.addDocument(new PdfReader(baos2.toByteArray()));
copy.addDocument(new PdfReader(pdfBytes));
copy.close();
baos.flush();

return baos1.toByteArray();
}

返回的 byte[] 非常好,并且可以在 Adob​​e Reader 中正确打开(与类似但可能不相关的 earlier question of mine 不同)。 问题是,当 PDF 关闭时,Reader 会抛出一个确认对话框:

"Do you want to save changes to 'someFilename.pdf' before closing?"

显然,没有需要保存的更改。 SO 上的其他线程暗示初始缓冲区量尾部的无关未使用字节是罪魁祸首。我不清楚该模式是否适用于这种情况,但如果我在 Debug模式下停止 IDE,并在返回之前检查 byte[],就会出现大量带有零 (0) 的连续字节。

但是,在这种情况下,我不知道如何确定字节数组的“正确”大小应该

更新:上面的代码示例现在反射(reflect)了 hoaz 的建议在注释中使用两个 ByteArrayOutputStream 。这解决了问题!

最佳答案

我将创建两个 BAOS 实例,一个用于压模,另一个用于缝合。

您的问题是您在标记后将单个 BAOS 写入自身,这会混合内容。

关于java - 将 PDF 与 iText 合并会导致关闭时出现 "Do you want to save changes...?"对话框,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13768362/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com