3

我在 iText / iTextSharp(通过 NuGet 的 iTextSharp 5.3.3)中的 XFA 表单有一个非常奇怪的问题。我正在尝试填写静态 XFA 样式的表格,但是我的更改没有生效。

我有两个版本的 iText in Action,并且一直在咨询第二版以及书中的 iTextSharp 代码示例转换。

背景:我有一个 XFA 表格,可以在我的计算机上使用 Adob​​e Acrobat 手动填写。使用 iTextSharp 我可以读取 Xfa XML 数据是什么并查看数据的结构。我本质上是在尝试用 iText 来模仿它。

当我添加数据并保存在 Acrobat 中时,数据是什么样的(注意:这只是数据集的特定部分)

在此处输入图像描述

这是我试图读入以替换现有数据的 XML 文件(注意:这是该文件的整个上下文):

在此处输入图像描述

但是,当我将路径传递到替换 XML 文件并尝试设置数据时,创建的新文件(已替换数据的原始文件的副本)没有抛出任何错误,但数据没有被更新。我可以看到新文件已创建,我可以打开它,但文件中没有数据。

这是第一次用于替换数据或填充的代码,它是http://sourceforge.net/p/itextsharp/code/HEAD/tree/trunk/book/iTextExamplesWeb/iTextExamplesWeb/iTextInAction2Ed/的变体Chapter08/XfaMovie.cs

public void Generate(string sourceFilePath, string destinationtFilePath, string replacementXmlFilePath)
    {
        PdfReader pdfReader = new PdfReader(sourceFilePath);
        using (MemoryStream ms = new MemoryStream())
        {
            using (PdfStamper stamper = new PdfStamper(pdfReader, ms))
            {
                XfaForm xfaForm = new XfaForm(pdfReader);
                XmlDocument doc = new XmlDocument();
                doc.Load(replacementXmlFilePath);
                xfaForm.DomDocument = doc;
                xfaForm.Changed = true;
                XfaForm.SetXfa(xfaForm, stamper.Reader, stamper.Writer);
            }

            var bytes = ms.ToArray();
            File.WriteAllBytes(destinationtFilePath, bytes);
        }
    }

任何帮助将不胜感激。

4

2 回答 2

2

我赞成您的回答,因为它不正确(我很高兴我对演示的引用使您再次查看了您的代码),但是现在我再次查看了您的原始代码,我认为最好使用书籍示例

public byte[] ManipulatePdf(String src, String xml) {
  PdfReader reader = new PdfReader(src);
  using (MemoryStream ms = new MemoryStream()) {
    using (PdfStamper stamper = new PdfStamper(reader, ms)) {
      AcroFields form = stamper.AcroFields;
      XfaForm xfa = form.Xfa;
      xfa.FillXfaForm(XmlReader.Create(new StringReader(xml)));
    }
    return ms.ToArray();
  }
}

如您所见,没有必要替换整个 XFA XML。如果使用FillXfaForm方法,数据就足够了。

注意:C#版本的例子见http://tinyurl.com/iiacsCH08(其他章节的例子把08改成01到16的数字)。

于 2013-05-12T16:59:57.257 回答
1

我发现了这个问题。替换 DomDocument 需要是新文档的整个合并 XML,而不仅仅是数据或数据集部分。

于 2013-05-12T14:34:49.987 回答