项目中有一功能是导出历史记录,可以导出pdf和excel,这里先说导出pdf。在网上查可以用那些方式导出pdf,用itext比较多广泛。
导出pdf可以使用两种方式,一是可以根据已有的pdf模板,进行生成文档。二是直接用代码生成pdf
一、使用模板生成pdf
1、添加依赖
<dependency>
<groupId>com.itextpdf</groupId>
<artifactId>itextpdf</artifactId>
<version>5.5.10</version>
</dependency>
<dependency>
<groupId>com.itextpdf</groupId>
<artifactId>itext-asian</artifactId>
<version>5.2.0</version>
</dependency>
2、创建word,创建需要的样式,例如,保存为pdf格式,
3、使用Adobe Acrobat 打开,打开内容编辑,选择编辑域,编辑域的名称与代码的数据属性名对应。
4、java代码
import java.io.ByteArrayOutputStream;
import java.io.FileOutputStream;
import java.util.Iterator;
import com.itextpdf.text.Document;
import com.itextpdf.text.pdf.AcroFields;
import com.itextpdf.text.pdf.PdfCopy;
import com.itextpdf.text.pdf.PdfImportedPage;
import com.itextpdf.text.pdf.PdfReader;
import com.itextpdf.text.pdf.PdfStamper;
/**
* @Title: CreatePdf.java
* @Description: TODO
* @author zhangjunhong
* @date 2018年10月22日
*/
public class CreatePdf {
public static void fillTemplate() throws Exception {
//读取的模板
String templatePath = "D:/mypdf1.pdf";
//生成的pdf存储的路径
String targetPath = "D:/test1.pdf";
PdfReader reader;
FileOutputStream outputStream;
ByteArrayOutputStream bos;
PdfStamper stamper;
reader = new PdfReader(templatePath);
outputStream = new FileOutputStream(targetPath);
bos = new ByteArrayOutputStream();
stamper = new PdfStamper(reader, bos);
//取得模板表单对应的域
AcroFields from = stamper.getAcroFields();
String[] strings = { "12222", "zahang", "男", "1992-09-12" };
int i = 0;
Iterator<String> iterator = from.getFields().keySet().iterator();
while (iterator.hasNext()) {
String name = iterator.next().toString();
System.err.println(name);
from.setField(name, strings[i++]);
}
stamper.setFormFlattening(true);
stamper.close();
Document document = new Document();
PdfCopy copy = new PdfCopy(document, outputStream);
document.open();
PdfImportedPage importedPage = copy.getImportedPage(new PdfReader(bos.toByteArray()), 1);
copy.addPage(importedPage);
document.close();
}
public static void main(String[] args) throws Exception{
fillTemplate();
}
}
5、结果
二、根据数据生成pdf并导出,这个好像挺简单的,直接代码一波,看注释,也可以生成表格之类的
@RequestMapping("/export/pdf")
public void exPdf(HttpServletResponse response){
OutputStream os=null;
try {
// 指定解析器
System.setProperty("javax.xml.parsers.DocumentBuilderFactory",
"com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderFactoryImpl");
String filename = "大面积延误历史记录详情.pdf";
response.setContentType("application/pdf");
response.setHeader("Content-Disposition",
"attachment;fileName=" + URLEncoder.encode(filename, "UTF-8"));
os = new BufferedOutputStream(response.getOutputStream());
//生成pdf
Document document=new Document();
PdfWriter writer=PdfWriter.getInstance(document, os);
// 页面大小
Rectangle rectangle = new Rectangle(PageSize.A4);
// 页面背景颜色
rectangle.setBackgroundColor(BaseColor.WHITE);
document.setPageSize(rectangle);
// 页边距 左,右,上,下
document.setMargins(20, 20, 20, 20);
document.open();
//中文字体 ----不然中文会乱码
BaseFont bf = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H",BaseFont.NOT_EMBEDDED);
//设置字体
Font font = new Font(bf, 14, Font.BOLD, BaseColor.BLACK);
Paragraph p=new Paragraph("设置了字体样式的标题哈哈哈哈哈今天比较闲嘤嘤嘤", font);
document.add(p);
document.close();
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
os.close();
} catch (IOException e) {
e.printStackTrace();
}
}
结果:访问路径http://127.0.0.1:8080/export/pdf,下载下来的pdf文档
还有很多对pdf的操作,如添加page,表格等,可查看itext的官方文档,
或者看这个博客:https://blog.csdn.net/weixin_36380516/article/details/76984283
最后是不是贴上我花了几天写的pdf导出,这个技术是简单了,尼玛项目业务逻辑贼复杂。周五任务完成截止日期,昨天写完啦,等前端对接接口,,就写写博客,算了,先不贴代码。我再整理整理