我有一个PDF文件,其中包含一些我需要从Java代码填写的表单字段。我使用iText 2.1.7库,这段代码:
PdfReader reader = new PdfReader("C:\\Users\\igor\\Desktop\\test.pdf");
PdfStamper stamper = new PdfStamper(reader, new FileOutputStream("testout.pdf"), '\0', true);
AcroFields fields = stamper.getAcroFields();
fields.setField("txtFirstName", "Milan");
stamper.close();
我收到此错误消息:
org.w3c.dom.DOMException: INVALID_CHARACTER_ERR: An invalid or illegal XML character is specified.
at com.sun.org.apache.xerces.internal.dom.CoreDocumentImpl.checkQName(CoreDocumentImpl.java:2582)
at com.sun.org.apache.xerces.internal.dom.ElementNSImpl.setName(ElementNSImpl.java:117)
at com.sun.org.apache.xerces.internal.dom.ElementNSImpl.<init>(ElementNSImpl.java:80)
at com.sun.org.apache.xerces.internal.dom.CoreDocumentImpl.createElementNS(CoreDocumentImpl.java:2095)
at com.lowagie.text.pdf.XfaForm$Xml2SomDatasets.insertNode(Unknown Source)
at com.lowagie.text.pdf.AcroFields.setField(Unknown Source)
at com.lowagie.text.pdf.AcroFields.setField(Unknown Source)
at proba.main(proba.java:21)
PDF不是由我创建的,所以我不知道文件使用的是什么类型的表单(如果我理解正确,则有FDF和XFA表单)。由于PDF不是由我创建的,因此我使用此工具http://support.persits.com/pdf/demo_formfields.asp找出表单字段的名称,它给了我这个:
applicationPrepaid[0].#pageSet[0].Pagina1[0].txtFirstName[0]
Pdftk工具只为txtFirstName
字段提供了字段名称。我尝试了全名,只是txtFirstName
而且它不起作用。帮助
答案 0 :(得分:1)
问题似乎在于您正在使用Basic页面。 名称'#pageSet [0'是导致错误的名称。我认为这是导致错误的'磅'(#)符号。