您的位置:首页 > 其它

iText编辑PDF动态生成文档,支持中文

2018-04-13 00:00 1721 查看
摘要: 适用于生成合同等固定模板业务场景,不适用实时提交word/excel系统动态编辑场景。

一、准备工作

1、首先制作word模板,然后另存为PDF。

2、使用AdobeAcrobat打开生成的PDF文档,在文档上添加表单域,保存生成模板。

具体步骤可以参照:https://www.cnblogs.com/LUA123/p/5108007.html
二、使用iText编辑制作好的PDF模板

直接上代码了,具体要注意的也都在注释里,支持中文

import java.io.ByteArrayOutputStream;
import java.io.FileOutputStream;
import java.io.IOException;

import com.itextpdf.text.Document;
import com.itextpdf.text.DocumentException;
import com.itextpdf.text.pdf.AcroFields;
import com.itextpdf.text.pdf.BaseFont;
import com.itextpdf.text.pdf.PdfCopy;
import com.itextpdf.text.pdf.PdfImportedPage;
import com.itextpdf.text.pdf.PdfReader;
import com.itextpdf.text.pdf.PdfStamper;

public class ItextEditPDF {

public void exportPdf() throws DocumentException, IOException {// 利用模板生成pdf
// 模板路径
String templatePath = "C:/TestCreatePDF/demo_table.pdf";
// 生成的新文件路径
String newPDFPath = "C:/TestCreatePDF/newPdf.pdf";
PdfReader reader;
FileOutputStream out;
ByteArrayOutputStream bos;
PdfStamper stamper;
BaseFont baseFont = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.NOT_EMBEDDED);
try {
out = new FileOutputStream(newPDFPath);// 输出流
reader = new PdfReader(templatePath);// 读取pdf模板
bos = new ByteArrayOutputStream();
stamper = new PdfStamper(reader, bos);
AcroFields form = stamper.getAcroFields();

String[] str = { "我是一个中国人121asdas", "我是一个中国人", "我是一个中国人", "1994-00-00" };
int i = 0;
java.util.Iterator<String> it = form.getFields().keySet().iterator();
while (it.hasNext()) {
String name = it.next().toString();
System.out.println(name);
// 设置支持中文
form.setFieldProperty(name, "textfont", baseFont, null);
form.setField(name, str[i++]);
}
stamper.setFormFlattening(true);// 如果为false那么生成的PDF文件还能编辑,一定要设为true
stamper.close();

Document doc = new Document();
PdfCopy copy = new PdfCopy(doc, out);
doc.open();
int pageCount = new PdfReader(bos.toByteArray()).getNumberOfPages();
System.out.println("pageCount = " + pageCount);
for (int pageNum = 1; pageNum <= pageCount; pageNum++) {
// 每一页都Copy
PdfImportedPage importPage = copy.getImportedPage(new PdfReader(bos.toByteArray()), pageNum);
copy.addPage(importPage);
}

doc.close();

} catch (IOException e) {
System.out.println("IOException" + e);
} catch (DocumentException e) {
System.out.println("DocumentException" + e);
}

}

public static void main(String[] args) throws DocumentException, IOException {
new ItextEditPDF().exportPdf();
}
}

以下是pom依赖

<dependency>
<groupId>com.itextpdf</groupId>
<artifactId>itextpdf</artifactId>
<version>5.5.13</version>
</dependency>
<dependency>
<groupId>com.itextpdf.tool</groupId>
<artifactId>xmlworker</artifactId>
<version>5.5.13</version>
</dependency>
<dependency>
<groupId>com.itextpdf</groupId>
<artifactId>itext-asian</artifactId>
<version>5.2.0</version>
</dependency>
<dependency>
<groupId>org.xhtmlrenderer</groupId>
<artifactId>flying-saucer-pdf</artifactId>
<version>9.0.3</version>
</dependency>

说明:代码基本来源于百度,因其他代码有各种各样的问题,这里都做了处理,已经可以作为工具类直接使用。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  iText PDF