这几天已在做处理导出pdf文件的功能,摸索了几天总算可以了。记录下这几天遇到的问题。

1.网上基本都是基于Itext5和Itext7来处理的。我最终是在Itext5上成功了,itext7应该是模板出问题了,在写的test方法里面测试时候,总是 找不到 pdf文档里面的form表单内容。因为需要使用adobe acrobat reader dc 来制作模板,而我没有这个。一直导致失败。

2.最终成功是参考这个文档:

https://blog.csdn.net/yi2419808933/article/details/52469241

https://blog.csdn.net/yi2419808933/article/details/52469241

3.贴上最终代码

 /**
* 导出对账单
* @return
*/
@RequestMapping("/exportSupplierFeeData")
@ResponseBody
@MasterSlaveConfigs(configs={
@MasterSlaveConfig(databaseTag="mdbcarmanage-DataSource",mode= DynamicRoutingDataSource.DataSourceMode.SLAVE)
} )
public AjaxResponse exportSupplierFeeData(HttpServletRequest request, HttpServletResponse response,
ServletOutputStream outputStream,
Integer cityId, Integer supplierId,
Integer status, Integer amountStatus, String settleStartDate,
String settleEndDate, String paymentStartTime, String paymentEndTime, String feeOrderNo){
logger.info(MessageFormat.format("查询司机线上化入参:cityId:%s,supplierId:%s,status:%s," +
"amountStatus:%s,settleStartDate:%s,settleEndDate:%s,paymentStartTime:%s,paymentEndTime:%s",cityId,supplierId,status,amountStatus,settleStartDate,settleEndDate,paymentStartTime,paymentEndTime)); response.setContentType("application/pdf;charset=ISO8859-1");
response.setHeader("Content-disposition", "attachment; filename="+"supplierFeePDF-1.pdf"); SupplierFeeManageDto feeManageDto = new SupplierFeeManageDto();
feeManageDto.setCityId(cityId);
feeManageDto.setSettleStartDate(settleStartDate);
feeManageDto.setSettleEndDate(settleEndDate);
feeManageDto.setAmountStatus(amountStatus);
feeManageDto.setStatus(status);
SupplierFeeManage manage = supplierFeeService.queryByOrderNo(feeOrderNo); String[] titles = { "供应商名称1", "列名t2", "列名3", "列名4", "t5", "t6","t7"};
try {
ByteArrayOutputStream ba = new ByteArrayOutputStream();
Document document = new Document(PageSize.A3); // Step 1—Create a Document.
PdfWriter writer;
writer = PdfWriter.getInstance(document, ba);
document.open(); document.setMargins(5, 5, 5, 5);
//H 代表文字版式是横版,相应的 V 代表竖版
BaseFont bfChinese = BaseFont.createFont("STSongStd-Light","UniGB-UCS2-H",BaseFont.NOT_EMBEDDED);//STSongStd-Light 是字体,在jar 中以property为后缀
//参数一:新建好的字体;参数二:字体大小,参数三:字体样式,多个样式用“|”分隔 Font topfont = new Font(bfChinese,14,Font.BOLD);
//BaseFont bf = BaseFont.createFont("" + "fonts/simsun.ttc,0", BaseFont.IDENTITY_H,
// BaseFont.EMBEDDED); Paragraph blankRow1 = new Paragraph(18f, " ");
blankRow1.setAlignment(Element.ALIGN_CENTER); PdfPTable table1 = new PdfPTable(titles.length); //创建一个表格,参数为一行有几栏
int width1[] = {100,150,150,100,50,50,55};//每栏的宽度
table1.setWidths(width1); //设置宽度 //首行
for(int i=0;i<titles.length;i++){
PdfPCell cell1 = new PdfPCell(new Paragraph(titles[i],topfont));
table1.addCell(cell1);
} //每栏的值
//PdfPCell cell1 = new PdfPCell(new Paragraph(manage.getSupplierId())); /* PdfPTable celltable = new PdfPTable(2); cell1 = new PdfPCell(celltable);
cell1.setRowspan(2);
cell1.setPadding(10);
table1.addCell(cell1);*/ PdfPCell cell1 = new PdfPCell(new Paragraph("5555",topfont));
table1.addCell(cell1);
PdfPCell cell2= new PdfPCell(new Paragraph(manage.getFlowAmount(),topfont));
table1.addCell(cell2); PdfPCell cell3= new PdfPCell(new Paragraph(manage.getSettleStartDate().toString(),topfont));
table1.addCell(cell3);
PdfPCell cell4= new PdfPCell(new Paragraph(manage.getPaymentTime().toString(),topfont));
table1.addCell(cell4);
PdfPCell cell5= new PdfPCell(new Paragraph(manage.getFeeOrderNo(),topfont));
table1.addCell(cell5);
PdfPCell cell6= new PdfPCell(new Paragraph(manage.getSupplierId().toString(),topfont));
table1.addCell(cell6);
PdfPCell cell7= new PdfPCell(new Paragraph(manage.getSupplierName().toString(),topfont));
table1.addCell(cell7); document.add(table1);//将表格加入到document中
// document.add(table2);
document.add(blankRow1);
document.close(); ba.writeTo(outputStream);
outputStream.flush();
outputStream.close(); ba.close(); // 导出pdf注解 } catch (Exception e) {
e.printStackTrace();
} // 模板路径 String templatePath = "/Users/fan/workspace/mp-manage/src/main/webapp/upload/supplierFeePDF-1.pdf"; // 生成的新文件路径
String newPDFPath = "/Users/fan/workspace/mp-manage/src/main/webapp/upload/supplierFeePDF-2.pdf";
/* PdfReader reader;
FileOutputStream out;
ByteArrayOutputStream bos;
PdfStamper stamper;
try {
out = new FileOutputStream(newPDFPath);// 输出流
reader = new PdfReader(templatePath);// 读取pdf模板
bos = new ByteArrayOutputStream(); stamper = new PdfStamper(reader, bos);
AcroFields form = stamper.getAcroFields();
*//*String[] str = {manage.getSupplierName(), DateUtils.formatDate(manage.getSettleStartDate()),DateUtils.formatDate(manage.getSettleEndDate()),
manage.getFlowAmount()};*//*
String[] str = { "123456789", "TOP__ONE", "男", "1991-01-01", "130222111133338888", "河北省保定市" };
java.util.Iterator<String> it = form.getFields().keySet().iterator(); *//*for(int i = 0;i<feeManageList.size();i++){
SupplierFeeManage feeManage = feeManageList.get(i); form.setField(null,feeManage.getSupplierName());
}*//* int i = 0;
while (it.hasNext()) {
String name = it.next().toString();
System.out.println(name);
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();
PdfImportedPage importPage = copy.getImportedPage(new PdfReader(bos.toByteArray()), 1);
copy.addPage(importPage);
doc.close();
} catch (IOException e) {
System.out.println(1);
} catch (DocumentException e) {
System.out.println(2);
}
*/
return null;
}

  

java导出pdf功能记录的更多相关文章

  1. JAVA导出pdf实例

    一.直接导出成PDF   Java代码 1. import java.io.FileNotFoundException; 2. import java.io.FileOutputStream; 3.  ...

  2. 导出pdf功能

    本程序下载地址: PDF是我们极其常用的文件格式,但对如何生成PDF,个人一直觉得很神秘,其实利用一些公开的PDF库,我们就可以直接生成PDF文件,而不用关注PDF文件的内部细节.我知道的PDF库有如 ...

  3. Java导出Pdf格式表单

    前言   作为开发人员,工作中难免会遇到复杂表单的导出,接下来介绍一种通过Java利用模板便捷导出Pdf表单的方式 模拟需求   需求:按照下面格式导出pdf格式的学生成绩单 准备工作 Excel软件 ...

  4. Java导出pdf文件数据

    提示:导出pdf文件,需要3个jar包iText-2.1.5.jar,iTextAsian.jar,iText-rtf-2.1.4.jar. public boolean outputPdfJhsy( ...

  5. java导出pdf

    //导出          public void ScoringAnnouncementdownLoad() throws MalformedURLException, IOException, D ...

  6. 一次java导出pdf的经历

    近期由于工作需要,需要将html代码导入到pdf中,经过了几种pdf的方案对比后发现IText是最简单和便捷的一种方式,于是乎采用了Itext. PDF生成 第一步:导入Maven依赖 <!-- ...

  7. C# 导出CSV功能记录下

    异常问题1: 如 机构编号 导出城CSV后,前面的四个0000不显示了, 解决办法 输出格式变为 =" 异常问题2: PPMABAT01:/MABATAPS/usr/ma_batas > ...

  8. java根据模板导出PDF详细教程

    原文:https://blog.csdn.net/pengyufight/article/details/75305128 题记:由于业务的需要,需要根据模板定制pdf文档,经测试根据模板导出word ...

  9. ASP.NET C#根据HTML页面导出PDF

    在启明星采购系统里,新增了导出PDF功能.整个功能使用了第三方软件 wkhtmltopdf(下载) 官网 https://wkhtmltopdf.org/ 提供有更多版本下载 他可以把HTML页面转换 ...

随机推荐

  1. table的各种用法

    使用 colgroup 和 col 实现响应式表格(table的各种用法):http://coderlt.coding.me/2017/11/20/table-colgroup/

  2. 30、Python程序中的线程操作(oncurrent模块)

    进程是cpu资源分配的最小单元,一个进程中可以有多个线程. 线程是cpu计算的最小单元. 对于Python来说他的进程和线程和其他语言有差异,是有GIL锁. GIL锁 GIL锁保证一个进程中同一时刻只 ...

  3. Oracle之常用sql

    SQL函数 本文PDF下载 本文示例数据库下载 一旦成功地从表中检索出数据,就需要进一步操纵这些数据,以获得有用或有意义的结果.这些要求包括:执行计算与数学运算.转换数据.解析数值.组合值和聚合一个范 ...

  4. 数据库join解释 与视图

    数据库的视图是表运算的结果. 数据库的表是数据单元: join是运算符: 视图是运算结果. 数据库join解释 1.join:将两个表结构连接成一个视图 2.left.right.inner: 从基准 ...

  5. [Inside HotSpot] Xcode编译调试OpenJDK12

    编译 下载brew然后安装hg,freetype,ccache $ /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent. ...

  6. reids 数据库学习

    最近项目中用到了redis数据库,学习整理下 redis操作学习手册--key操作命令 http://www.cnblogs.com/stephen-liu74/archive/2012/03/26/ ...

  7. js-Cannot read property 'innerHTML' of null

    原因:1.$('#xxx') 或$('.xxx')不存在 2.$('#xxx')或$('.xxx')的值为空

  8. linux 下安装git的步骤方法

    ①.获取github最新的Git安装包下载链接,进入Linux服务器,执行下载,命令为: wget https://github.com/git/git/archive/v2.17.0.tar.gz  ...

  9. 洛谷/Codeforces CF865D 题解

    若想要深入学习反悔贪心,传送门. Description: 已知接下来 \(n\) 天的股票价格,每天可以买入当天的股票,卖出已有的股票,或者什么都不做,求 \(n\) 天之后最大的利润. Metho ...

  10. 使用Lua脚本通过原子减防止超卖

    需求 双十二要搞一个一分钱门票抢购的活动. 分析 性能分析,抢购时会发生高并发,如果仅仅依靠Mysql数据库,有可能因为大量的请求频繁访问数据库造成服务器雪崩,所以考虑通过Redis减库存,最终的数据 ...