之前用过一次wkhtmltopdf忘了,综合网上查找的资料,这次写下来记录一下。
安装步骤(Linux):
1. 根据自己的Linux版本从下面网址下载快很多,官网太慢了
wkhtmltopdf各版本地址(推荐):GitHub版本地址
wkhtmltopdf的centos7版本下载地址:wkhtmltopdf的centos7版本下载
官网(太慢不推荐)地址:官网
2. 部署教程
随便找个路径上传安装包,我的路径是/usr/local/wkhtmltopdf,输入如下命令
rpm -ivh wkhtmltox-0.12.5-1.centos7.x86_64.rpm
出现缺少依赖,根据提示缺少什么就yum什么。我这缺少的依赖包如下:
yum install xorg-x11-fonts-75dpi.noarch
yum install xorg-x11-fonts-Type1.noarch
yum install libXrender
yum install libXext
再次rpm -ivh wkhtmltox-0.12.5-1.centos7.x86_64.rpm安装即可
3. 测试
测试命令
wkhtmltopdf http://www.baidu.com.com test.pdf
wkhtmltopdf hmlt地址 pdf转换后存储地址
当前目录下,也就是你执行命令的当前目录下会出现test.pdf文件,说明安装成功
找到安装目录,我这安装目录是: /usr/local/bin/wkhtmltopdf
4. 检查字体
需要存在simsun.ttc字体,避免pdf中文乱码,如下目录
/usr/share/fonts/simsun/simsun.ttc
windows版本就不多说自己下了,是个exe安装程序,安装好了就行,自己去系统变量path设置F:\wkhtmltopdf\1\wkhtmltopdf\bin全局变量。
Java集成:
核心代码:
Runtime.getRuntime().exec();
HtmlToPdfInterceptor.java
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
/**
* wkhtmltopdf.exe执行信息拦截
*
*/
public class HtmlToPdfInterceptor extends Thread {
private InputStream is;
public HtmlToPdfInterceptor(InputStream is){
this.is = is;
}
public void run(){
try{
InputStreamReader isr = new InputStreamReader(is, "utf-8");
BufferedReader br = new BufferedReader(isr);
String line = null;
while ((line = br.readLine()) != null) {
System.out.println(line.toString()); //输出内容
}
}catch (IOException e){
e.printStackTrace();
}
}
}
HtmlToPdf.java
import java.io.File;
import com.rf.arb.Interceptor.HtmlToPdfInterceptor;
public class HtmlToPdf {
//wkhtmltopdf在系统中的路径
private static final String toPdfTool = "F:\\wkhtmltopdf\\1\\wkhtmltopdf\\bin\\wkhtmltopdf.exe";
/**
* html转pdf
* @param srcPath html路径,可以是硬盘上的路径,也可以是网络路径
* @param destPath pdf保存路径
* @return 转换成功返回true
*/
public static boolean convert(String srcPath, String destPath){
File file = new File(destPath);
File parent = file.getParentFile();
//如果pdf保存路径不存在,则创建路径
if(!parent.exists()){
parent.mkdirs();
}
StringBuilder cmd = new StringBuilder();
if(System.getProperty("os.name").indexOf("Windows") == -1){
//非windows 系统
//toPdfTool = FileUtil.convertSystemFilePath("/home/ubuntu/wkhtmltox/bin/wkhtmltopdf");
}
cmd.append(toPdfTool);
cmd.append(" ");
/*
cmd.append(" --header-line");//页眉下面的线
//cmd.append(" --header-center 这里是页眉这里是页眉这里是页眉这里是页眉 ");//页眉中间内容
cmd.append(" --margin-top 3cm ");//设置页面上边距 (default 10mm)
cmd.append(" --header-html file:///"+WebUtil.getServletContext().getRealPath("")+FileUtil.convertSystemFilePath("\\style\\pdf\\head.html"));// (添加一个HTML页眉,后面是网址)
cmd.append(" --header-spacing 5 ");// (设置页眉和内容的距离,默认0)
//cmd.append(" --footer-center (设置在中心位置的页脚内容)");//设置在中心位置的页脚内容
cmd.append(" --footer-html file:///"+WebUtil.getServletContext().getRealPath("")+FileUtil.convertSystemFilePath("\\style\\pdf\\foter.html"));// (添加一个HTML页脚,后面是网址)
cmd.append(" --footer-line");//* 显示一条线在页脚内容上)
cmd.append(" --footer-spacing 5 ");// (设置页脚和内容的距离)
*/
cmd.append(srcPath);
cmd.append(" ");
cmd.append(destPath);
boolean result = true;
try{
Process proc = Runtime.getRuntime().exec(cmd.toString());
HtmlToPdfInterceptor error = new HtmlToPdfInterceptor(proc.getErrorStream());
HtmlToPdfInterceptor output = new HtmlToPdfInterceptor(proc.getInputStream());
error.start();
output.start();
proc.waitFor();
}catch(Exception e){
result = false;
e.printStackTrace();
}
return result;
}
public static void main(String[] args) {
HtmlToPdf.convert("F:\\wkhtmltopdf\\test\\test.html", "F:\\wkhtmltopdf\\test\\test1.pdf");
}
}
偷懒的同学直接复制上述代码,类名一致即可测试,hmlt路径和pdf存储路径跟代码一致就行。重要说明,toPdfTool 需要你的window安装的wkhtmltopdf绝对路径。
至于代码中的WebUtil.java和FileUtil.java,我查的资料没有给明源代码,所以我把部分cmd.append()的代码注释,这并不影响pdf的转换,亲测可用。
总结:
1.完全可以按照文中的教程一步一步来,文中所需的各种路径完全可以一致,上手后根据自己需求更改。
2.部署过程中,可能缺少的依赖会更多,也可能会少,并不是一定跟文中所提的依赖缺少相同,切记根据提示来yum缺少依赖。
最后说一句,文中有错误,或者部署和集成过程中有不可解决的问题,可以评论下来,我会及时并不日回复。