这是一种可能的解决方案 . 它可能不是你想要的解决方案,但是...这不是我们的错,因为你让我们猜测你的意图 .
假设您有一个包含单个页面的PDF文档:state.pdf
您想在此页面中添加一些文本,因此它看起来像这样:california.pdf
你不想这样做一次,但你想多次这样做,所以你得到这个:united_states_2.pdf
在这种情况下,您需要 PdfStamper (将内容添加到单个页面)和 PdfSmartCopy (组合不同页面而不膨胀文档)的组合 .
public void manipulatePdf(String src, String dest) throws DocumentException, IOException {
Document document = new Document();
PdfCopy copy = new PdfSmartCopy(document, new FileOutputStream(dest));
document.open();
ByteArrayOutputStream baos;
PdfReader reader;
PdfStamper stamper;
AcroFields fields;
StringTokenizer tokenizer;
BufferedReader br = new BufferedReader(new FileReader(DATA));
String line = br.readLine();
while ((line = br.readLine()) != null) {
// create a PDF in memory
baos = new ByteArrayOutputStream();
reader = new PdfReader(SRC);
stamper = new PdfStamper(reader, baos);
fields = stamper.getAcroFields();
tokenizer = new StringTokenizer(line, ";");
fields.setField("name", tokenizer.nextToken());
fields.setField("abbr", tokenizer.nextToken());
fields.setField("capital", tokenizer.nextToken());
fields.setField("city", tokenizer.nextToken());
fields.setField("population", tokenizer.nextToken());
fields.setField("surface", tokenizer.nextToken());
fields.setField("timezone1", tokenizer.nextToken());
fields.setField("timezone2", tokenizer.nextToken());
fields.setField("dst", tokenizer.nextToken());
stamper.setFormFlattening(true);
stamper.close();
reader.close();
// add the PDF to PdfCopy
reader = new PdfReader(baos.toByteArray());
copy.addDocument(reader);
reader.close();
}
br.close();
document.close();
}
如果这不是您想要的,请澄清您的问题 . 在任何情况下:这个答案是对你的问题的许多可能的正确解释之一 .