3

希望有人能看到我的代码中的缺陷,以便使用 ITextSharp 合并到 PDF-a 文档。目前它抱怨缺少 PDF-a 所需的元数据。

Document document = new Document();
MemoryStream ms = new MemoryStream();
using (PdfACopy pdfaCopy = new PdfACopy(document, ms, PdfAConformanceLevel.PDF_A_1A))
{
    document.Open();
    using (PdfReader reader = new PdfReader("Doc1.pdf"))
    {
        pdfaCopy.AddDocument(reader);
    }
    using (PdfReader reader = new PdfReader("doc2.pdf"))
    {
        pdfaCopy.AddDocument(reader);
    }
}

收到的确切错误是

未处理的异常:iTextSharp.text.pdf.PdfAConformanceException:符合 PDF/A 的文件的文档目录字典应包含元数据键

我希望“文档目录字典”也会被复制,但我猜“新文档()”会创建一个空的不合格文档或其他东西。

谢谢!希望你能帮忙

沃特

4

1 回答 1

2

您需要添加这一行:

copy.CreateXmpMetadata();

这将创建一些默认的 XMP 元数据。当然:如果您想创建自己的 XMP 文件,其中包含有关您将要合并的文档的信息,您还可以使用:

copy.XmpMetadata = myMetaData;

其中myMetaData是包含正确 XMP 流的字节数组。

我希望您了解 iText 无法自动创建正确的元数据。提供元数据是需要人类关注的事情。

于 2014-07-31T16:08:10.427 回答