最完美的html转化为pdf的方法

  • 几种常见的html页面转化为pdf的方法
    • html2canvas+jsPDF
    • iText
    • wkhtmltopdf
  • wkhtmltopdf安装部署,php调用的方法
    • 安装wkhtmltopdf
    • php调用wkhtmlpdf
      • composer安装
      • 安装mikehaertl/phpwkhtmltopdf依赖
      • php调用wkhtmltopdf
  • 心得总结

一、常见的几种html转化pdf方法

最常见的html转化为pdf的方法肯定是在浏览器中ctrl+p的快捷键(windows)就可以直接将页面导出为pdf了,当然这对于用户来说肯定是不够友好的,在网页开发中这肯定也是不合格的。所以引入了下面三种方法。

1. html2canvas+jsPDF

这种方法实质上是一种专门在前端js生成pdf的方法,只要导入几个js文件写一点js调用即可,本质就是使用js遍历页面中都dom节点,然后将其转化为canvas,然后调用jsPDF,将canvas转化为PDF,我也尝试的使用过这种方式生成PDF,使用感受一个是转成的PDF严重失帧,变形严重(当然不排除我html代码规范问题),另一个就是当页数过多时,会导致浏览器死机,速度过慢。

2. iText

这种方法生成的pdf质量会更高,但是在后端实现的步骤过于复杂,而且需要安装字体,对于html代码要求也是比较高,缺少标签的时候会报错,这种方法我没有去尝试过,当时直接被第三种方法给吸引了

3. wkhtmltopdf

这种方式实现比较简单,wkhtmltopdf是一个软件,这个软件生成pdf支持多种方式,可以直接使用网页网址将页面转化为pdf,也可以使用本地的文件将其转为pdf,而且转化结果及其的完美,加上实现的过程比较简单,所以我觉得这是最优的一种html转化为pdf的方式,下面直接上效果图

实际网页

转化pdf效果

转化的结果已经十分完美

我在项目中使用的是php调用wkhtmltopdf去生成pdf,下面内容会详细介绍说明步骤


二、wkhtmltopdf环境安装和使用

使用wkhtmltopdf应用到项目中实际上应该是这样一个过程,服务器安装好wkhtmltopdf软件,php后端将要转化的网页的html代码或者html文件在本地生成pdf,然后将服务器端的pdf发送到前端供用户下载或者浏览,其中php后端调用wkhtmltopdf的方法使用的是composer中的mikehaertl/phpwkhtmltopdf

1. 安装wkhtmltopdf

安装wkhtmltopdf过程很简单,这里不赘述,在wkhtmltopdf官网选择适合你系统的安装包下载安装即可,安装过程没有难度,一路确定到底就可以,安装完在你电脑里给他增加一个环境变量,将wkhtmltopdf的安装目录下面的bin目录加入环境变量path之中即可。打开命令行输入wkhtmltopdf -V会显示版本号说明安装成功

安装成功

这个时候就可以直接使用软件了你可以简单的使用一下这个软件,直接复制下面的html另存为test.html

<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
    <p>hello, you are succeed</p>
</body>
</html>

在cmd命令行中打开test.html所在文件夹然后使用命令wkhtmltopdf test.html test.pdf就会发现当前文件夹下出现了test.pdf的文件

4.jpg

5.jpg

命令中可以使用在线的网址来代替本地html文件,不过一般最好不要在项目中这样使用,因为网页中容易有各种表单参数和iframe容易出错,在项目中使用html文件转化

2. php调用wkhtmlpdf

前面说了一大串,但是其实都是比较简单,下面说的才是使用的关键,前面只是本地用命令行使用软件,但是实际中应该是用后端语言调用这个软件。使用composer中的mikehaertl/phpwkhtmltopdf包。

1. composer安装

首先还是得安装配置环境,php的基本环境就不多说了,这里说的是安装一个包管理composer,使用composer来管理自己的php的各种包。
composer官网选择适合的版本下载安装,在命令行中输入composer --version显示版本号即安装成功

安装成功
2. 安装mikehaertl/phpwkhtmltopdf依赖

安装依赖之前最好还是改变一下composer的下载镜像路径,改为国内路径 直接在命令行中输入composer config -g repo.packagist composer https://packgist.phpcomposer.com即可改变下载路径

然后cmd进入你的项目路径,输入你的命令composer require mikehaertl/phpwkhtmltopdf进行依赖的安装,等待安装成功既可,过程中可以会出现一些错误,但是优秀的你使用百度既可以解决这些问题。

3. php调用wkhtmltopdf

安装成功后过程其实就简单了,前面的安装看着简单,但是如果经验实在是不足就会导致哪里卡了半天,最少我当时就是折腾了半天的,多折腾好处多。最简单的调用就是php控制器页面写入下面的代码

use mikehaertl\wkhtmlto\Pdf;

// You can pass a filename, a HTML string, an URL or an options array to the constructor
$pdf = new Pdf('/path/to/page.html');

// On some systems you may have to set the path to the wkhtmltopdf executable
// $pdf->binary = 'C:\...';

if (!$pdf->saveAs('/path/to/page.pdf')) {
    $error = $pdf->getError();
    // ... handle error here
}

这个代码在本地调试一般是不会有问题,但是到了一些服务器就需要设置二进制路径,也就是你安装的wkhtmltopdf软件的路径,在上面打代码里面加一行$pdf->binary = 'C:\...';即可,这里是血的教训,当时一直不成功就是因为少了这一行代码,本机调试没问题,一到服务器就报错。
更加详细的使用说明可以前往github官网进行查看


三、心得总结

写这篇文章的目的一个是记录自己在学习路上遇见的难题,估计哪一天看见会有不一样的感触,另一个就是当时在查找html转化pdf的时候走了太多的歪路,网上的攻略零零散散,我踩了一个又一个坑,花了好几天的时间才最终实现了我想要的一些功能,这一切实现都不易,每次学习都会有一大堆的坑让我去踩,在坑里跳不出来的时候很痛苦,一度很想放弃,可是等到走出来的时候又是生出自豪之情,真的是让人又讨厌又享受。

----东湖小菜鸟匍匐前行之路

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,491评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,856评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,745评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,196评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,073评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,112评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,531评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,215评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,485评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,578评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,356评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,215评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,583评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,898评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,497评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,697评论 2 335

推荐阅读更多精彩内容