第一步,下载jar包以及建对应的文件夹。注意pd4ml的jar要选择pro版本。然后建一个pd4fonts.properties

里面对应的字体。

SimSun = simsun.ttf

前面为变量名,后面要对应你下载好的字体。网上都有各种字体下载。相应步骤做完了,做完后的文件夹如图格式都有了!

注意要引入图片中对应的jar下面的三个jar包到项目中去。

以下为从文件读取到数据再作导出功能。

import java.awt.Insets;

import java.io.BufferedInputStream;

import java.io.ByteArrayOutputStream;

import java.io.File;

import java.io.FileInputStream;

import java.io.IOException;

import java.io.StringReader;

import java.net.MalformedURLException;

import java.security.InvalidParameterException;

import org.zefer.pd4ml.PD4Constants;

import org.zefer.pd4ml.PD4ML;

public class Test {

protected int topValue = 10;

protected int leftValue = 20;

protected int rightValue = 10;

protected int bottomValue = 10;

protected int userSpaceWidth = 1300;

/**

* @param args

*/

public static void main(String[] args) {

try {

Test jt = new Test();

//此处填写你的html文件

String html = readFile("/Users/wangchen/Desktop/370fx2.html", "UTF-8");

//此处填写你下载的地方

jt.doConversion2(html, "/Users/wangchen/Desktop/370fx2.pdf");

} catch (Exception e) {

e.printStackTrace();

}

}

public void doConversion2(String htmlDocument, String outputPath)

throws InvalidParameterException, MalformedURLException,

IOException {

PD4ML pd4ml = new PD4ML();

pd4ml.enableDebugInfo();

pd4ml.setHtmlWidth(userSpaceWidth);

pd4ml.setPageSize(pd4ml.changePageOrientation(PD4Constants.A4));

pd4ml.setPageInsetsMM(new Insets(topValue, leftValue, bottomValue,

rightValue));

//此处的classPath注意一定要获取到你放fonts的文件夹。他需要获取到你下载的字体

String classPath = Test.class.getResource("/")+"fonts";

pd4ml.useTTF(classPath, true);

pd4ml.setDefaultTTFs("SimSun", "SimSun", "SimSun");

ByteArrayOutputStream baos = new ByteArrayOutputStream();

pd4ml.render(new StringReader(htmlDocument), baos);

baos.close();

File output = new File(outputPath);

java.io.FileOutputStream fos = new java.io.FileOutputStream(output);

fos.write(baos.toByteArray());

fos.close();

}

private final static String readFile(String path, String encoding)

throws IOException {

File f = new File(path);

FileInputStream is = new FileInputStream(f);

BufferedInputStream bis = new BufferedInputStream(is);

ByteArrayOutputStream fos = new ByteArrayOutputStream();

byte buffer[] = new byte[2048];

int read;

do {

read = is.read(buffer, 0, buffer.length);

if (read > 0) {

fos.write(buffer, 0, read);

}

} while (read > -1);

fos.close();

bis.close();

is.close();

return fos.toString(encoding);

}

}

如上你就可以下载将html转为pdf了。任意文本也可以转为pdf,经测试,可用

附件如下:https://pan.baidu.com/s/1wSvBM6Kti4IpI9IlDaycew

以下为浏览器下载pdf的工具类。直接调用红色的方法即可。htmlDocument 为你要导出的数据,response为该次请求的响应体,fileName为下载的名字

package com.ccb.common.utils;

import org.apache.commons.io.output.ByteArrayOutputStream;

import org.apache.commons.lang3.StringUtils;

import javax.servlet.http.HttpServletResponse;

import java.awt.*;

import java.io.*;

import java.security.InvalidParameterException;

import org.zefer.pd4ml.PD4Constants;

import org.zefer.pd4ml.PD4ML;

/**

* @author caihong

* @time 2019/1/28

*/

public class PDFUtil {

private static String PDF_TYPE="application/pdf";

private static String classpath=PDFUtil.class.getResource("/").getPath();

protected static int topValue = 10;

protected static int leftValue = 20;

protected static int rightValue = 10;

protected static int bottomValue = 10;

protected static int userSpaceWidth = 1300;

public static void pdf4htmlToPdf(String htmlDocument,HttpServletResponse response, String filename)throws InvalidParameterException,

IOException {

PD4ML pd4ml = new PD4ML();

pd4ml.enableDebugInfo();

pd4ml.setHtmlWidth(userSpaceWidth);

pd4ml.setPageSize(pd4ml.changePageOrientation(PD4Constants.A4));

pd4ml.setPageInsetsMM(new Insets(topValue, leftValue, bottomValue,rightValue));

pd4ml.useTTF(classpath+"fonts", true);

pd4ml.setDefaultTTFs("SimSun", "SimSun", "SimSun");

ByteArrayOutputStream baos = new ByteArrayOutputStream();

pd4ml.render(new StringReader(htmlDocument), baos);

baos.close();

renderPdf(response,baos.toByteArray(),filename);

}

public static void renderPdf(HttpServletResponse response, final byte[] bytes, final String filename) {

initResponseHeader(response, PDF_TYPE);

setFileDownloadHeader(response, filename, ".pdf");

if (null != bytes) {

try {

response.getOutputStream().write(bytes);

response.getOutputStream().flush();

} catch (IOException e) {

throw new IllegalArgumentException(e);

}

}

}

/**

* 分析并设置contentType与headers.

*/

private static HttpServletResponse initResponseHeader(HttpServletResponse response, final String contentType, final String... headers) {

// 分析headers参数

String encoding = "utf-8";

boolean noCache = true;

for (String header : headers) {

String headerName = StringUtils.substringBefore(header, ":");

String headerValue = StringUtils.substringAfter(header, ":");

if (StringUtils.equalsIgnoreCase(headerName, "utf-8")) {

encoding = headerValue;

} else if (StringUtils.equalsIgnoreCase(headerName, "no-cache")) {

noCache = Boolean.parseBoolean(headerValue);

} else {

throw new IllegalArgumentException(headerName + "不是一个合法的header类型");

}

}

// 设置headers参数

String fullContentType = contentType + ";charset=" + encoding;

response.setContentType(fullContentType);

if (noCache) {

// Http 1.0 header

response.setDateHeader("Expires", 0);

response.addHeader("Pragma", "no-cache");

// Http 1.1 header

response.setHeader("Cache-Control", "no-cache");

}

return response;

}

/**

* 设置让浏览器弹出下载对话框的Header.

* @param

*/

public static void setFileDownloadHeader(HttpServletResponse response, String fileName, String fileType) {

try {

// 中文文件名支持

String encodedfileName = new String(fileName.getBytes("GBK"), "ISO8859-1");

response.setHeader("Content-Disposition", "attachment; filename=\"" + encodedfileName + fileType + "\"");

} catch (UnsupportedEncodingException e) {

}

}

private final static String readFile(String path, String encoding)

throws IOException {

File f = new File(path);

FileInputStream is = new FileInputStream(f);

BufferedInputStream bis = new BufferedInputStream(is);

java.io.ByteArrayOutputStream fos = new java.io.ByteArrayOutputStream();

byte buffer[] = new byte[2048];

int read;

do {

read = is.read(buffer, 0, buffer.length);

if (read > 0) {

fos.write(buffer, 0, read);

}

} while (read > -1);

fos.close();

bis.close();

is.close();

return fos.toString(encoding);

}

}

自己完成controller,以及mapping映射后,注意要用get请求

http://localhost:8080/api/img/exportPdf?htmlDocument=12%E7%9A%84%E5%8F%91%E9%A1%BA%E4%B8%B0%E9%98%BF%E6%96%AF%E9%A1%BF%E5%8F%91%E9%80%81%E5%88%B0%E5%8F%91%E9%80%81%E5%A4%A7&fileName=123

便可以下载pdf了

java pdf中文乱码_java转pdf(html转为pdf),解决中文乱码,标签不规范等问题相关推荐

  1. java 读取txt乱码_java 逐行读取txt文本如何解决中文乱码

    java读取txt文本中如含有中文,可能会出现乱码,解决方案是: 1.要统一编码,java工程的编码,txt文本编码,java工程中的java文本编码都统一为utf-8: 2.利用 InputStre ...

  2. java调用 restapi 乱码_Java HttpURLConnection模拟请求Rest接口解决中文乱码问题

    public staticString PostRequest(String URL,String obj) { String jsonString="";try{//创建连接 U ...

  3. JAVA之NIO按行读写大文件,完美解决中文乱码问题

    JAVA之NIO按行读写大文件,完美解决中文乱码问题 参考文章: (1)JAVA之NIO按行读写大文件,完美解决中文乱码问题 (2)https://www.cnblogs.com/jpfss/p/89 ...

  4. java pdf文件保存_java根据模板文件导出pdf

    原文:https://www.cnblogs.com/wangpeng00700/p/8418594.html 在网上看了一些Java生成pdf文件的,写的有点乱,有的不支持写入中文字体,有的不支持模 ...

  5. java pdf 转word源码_Java 实现word模板转为pdf

    1. pom相关依赖 工具poi-tl (操作word文档模板) + jacob (将操作后的word模板转为pdf) com.deepoove poi-tl 1.9.1 com.jacob jaco ...

  6. java生成pdf盖章合同_Java中使用 FreeMarker 生成pdf盖章合同文件

    [实例简介] 1.html模板+model数据,通过freemarker进行渲染,便于维护和修改 2.渲染后的html流,可通过Flying Saucer组件生成pdf文件流,或者生成pdf后再转成j ...

  7. java 图片合成pdf_java将多张图片合并转为PDF

    所需jar包:com.lowagie.text package weaver.gy.util; import java.awt.image.BufferedImage; import java.io. ...

  8. java printwriter乱码_Java servlet 使用 PrintWriter 时的编码与乱码的示例代码

    在前面的网页中的编码与乱码系列中,曾多次提到使用 servlet 方式构建的动态响应流,不过在那里都是直接使用字节流的方式,不过,更为常见的方式是使用字符流.而在前面,又谈到了 Java 字节流与字符 ...

  9. html 转换成 pdf js,JS实现的将html转为pdf功能【基于浏览器端插件jsPDF】

    本文实例讲述了JS实现的将html转为pdf功能.分享给大家供大家参考,具体如下: jsPDF插件 HTML content... 中文 中国,汉字,测试:合同 模版 中国中国中国中国中国中国中国中国 ...

  10. nodejs+html转换pdf,Nodejs中使用phantom将html转为pdf或图片格式的方法

    最近在项目中遇到需要把html页面转换为pdf的需求,并且转换成的pdf文件要保留原有html的样式和图片.也就是说,html页面的图片.表格.样式等都需要完整的保存下来. 最初找到三种方法来实现这个 ...

最新文章

  1. Windows自动启动程序的十大藏身之所(转载)
  2. 《从问题到程序:用Python学编程和计算》——第2章 计算和编程初步 2.1 数值表达式和算术...
  3. struct 与class 的区别?
  4. 我们用4行代码节省了100万 记录与阿里云PCDN相遇全过程
  5. 团队-团队编程项目作业名称-成员简介及分工
  6. 计算机一级access考试题库,‎App Store 上的“计算机二级access-全国计算机等级考试题库”...
  7. 计算机无法开机按了f2,开机提示按f2 解决电脑开机时总是提示按F2 to continue的方法...
  8. [Qt教程] 第44篇 进阶(四)信号和槽
  9. STL 之fill和fill_n
  10. echarts --- 多折线图按段显示颜色规则订制
  11. 情感数据对LSTM股票预测模型的影响研究
  12. PostgreSQL extra_float_digits——控制浮点数精度
  13. 素数表的C++实现:快速进行素数筛选(埃氏筛法)
  14. 频谱分析仪的作用是什么?TFN FAT811手持式频谱分析仪
  15. 函数求和公式计算机出库入库,Excel 库存统计相关函数及制作库存统计表
  16. java lambda排序
  17. android仿QQ列表的效果实现
  18. Redis一主二从Sentinel监控配置
  19. 基于贪心选择及斜率探测扩充的轨面提取方法
  20. SAP 后台表查询方法及消息报错定位方法

热门文章

  1. 实现verilog设计控制交通灯
  2. mysql btree检索策略_MySQL之Btree索引和HASH索引的区别以及索引优化策略
  3. java负数转换二进制表示_Java中的负数的在计算机中的二进制表示,以及与十进制的相互转换...
  4. 单片机控制两个步进电机画圆_51单片机控制两个步进电机
  5. python中变量和函数的区别_关于python中带下划线的变量和函数 的意义
  6. 升级php影响zabbix吗,zabbix2.0升级到zabbix3.0
  7. c mysql 查不到数据_怎么检测不到MYSQL数据库的存在
  8. 【牛客挑战赛31D】 雷的打字机
  9. netty源码解解析(4.0)-3 Channel的抽象实现
  10. 2016 大连网赛---Weak Pair(dfs+树状数组)