PDF文档导出
1.介绍:此文档是根据自己制作的模板进行文档赋值导出。
2.环境(工具):Adobe Acrobat DC
3.POM文件
com.alibaba
fastjson
1.2.24
net.sf.json-lib
json-lib
2.4
jdk15
org.apache.struts
struts2-core
2.3.15.1
com.itextpdf
itext-asian
5.2.0
com.itextpdf
itextpdf
5.4.3
javax.servlet
servlet-api
3.0-alpha-1
4.制作PDF模板
新创建一个word,另存为PDF格式
用上边的Adobe Acrobat DC 工具打开,并打开表单编辑
下面就是需要填写的赋值数据,和代码里添加的key值名字对应.保存.
5.代码
PDFUtil工具类
package com.example.firstBootdemo.controller;
import com.itextpdf.text.Document;
import com.itextpdf.text.DocumentException;
import com.itextpdf.text.pdf.*;
import javax.servlet.ServletOutputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.util.Map;
public class PdfUtil {
/**
* @param o 写入的数据* @param templatePath pdf模板路径
* @param out 自定义保存pdf的文件流
*/
// 利用模板生成pdf
public void fillTemplate(Map<String, Object> o, ServletOutputStream out) {
PdfReader reader;
ByteArrayOutputStream bos;
PdfStamper stamper;
try {
// 读取pdf模板 这个是读取项目Resource文件夹下面的模板
reader = new PdfReader(Thread.currentThread().getContextClassLoader().getResource(“demo/测试.pdf”).getFile());
bos = new ByteArrayOutputStream();
stamper = new PdfStamper(reader, bos);
AcroFields form = stamper.getAcroFields();
//解决PDF导出不显示问题 加的字体格式
BaseFont bfChinese = BaseFont.createFont(“STSong-Light”, “UniGB-UCS2-H”,
BaseFont.NOT_EMBEDDED);
form.addSubstitutionFont(bfChinese);
java.util.Iterator<String> it = form.getFields().keySet().iterator();
while (it.hasNext()) {
String name = it.next().toString();
System.out.println(name);
String value = o.get(name) != null ? o.get(name).toString() : null;
form.setField(name, value);
}
stamper.setFormFlattening(true);// 如果为false那么生成的PDF文件还能编辑,一定要设为true
stamper.close();
Document doc = new Document();
PdfCopy copy = new PdfCopy(doc, out);
doc.open();
reader.getNumberOfPages();
PdfImportedPage importPage = null;
///循环是处理成品只显示一页的问题
for (int i = 1; i <= reader.getNumberOfPages(); i++) {
importPage = copy.getImportedPage(new PdfReader(bos.toByteArray()), i);
copy.addPage(importPage);
}
doc.close();
} catch (IOException e) {
System.out.println(e);
} catch (DocumentException e) {
System.out.println(e);
}
}
}
Controller层代码
@ResponseBody
@RequestMapping("/pdf")
public String downloadFile(HttpServletResponse response) throws UnsupportedEncodingException {
//假数据
Map<String, Object> map = new HashMap<>();
map.put(“companyName”, “孙尚香”);
map.put(“legalRepresentative”, “孙尚香”);
map.put(“beneficiarySName”, “孙尚香”);
map.put(“nationalityOfBeneficiary”, “孙尚香”);
map.put(“typeofBeneficiaryCertificate”, “孙尚香”);
map.put(“beneficiaryCertificateNumber”, “孙尚香”);
String json = JSON.toJSONString(map);
try {
json = java.net.URLDecoder.decode(json, "utf-8"); //解码
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
JSONObject jsonObject = JSONObject.fromObject(json);
Map<String, Object> mapJson = JSONObject.fromObject(jsonObject);
// = ServletActionContext.getResponse();
// 设置response参数,可以打开下载页面
response.reset();
response.setCharacterEncoding("utf-8");
// 定义输出类型
/*
*
* */
// 设置浏览器以下载的方式处理该文件名
String fileName = "测试.pdf";
response.setContentType("application/PDF;charset=utf-8");
response.setHeader("Content-Disposition", "attachment;filename=".concat(String.valueOf(URLEncoder.encode(fileName, "UTF-8"))));
try {
ServletOutputStream out = response.getOutputStream();
PdfUtil pdf = new PdfUtil();
pdf.fillTemplate(mapJson, out);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return null;
}