-
一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
- 网站名称:一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
- 网站分类:技术文章
- 收录时间:2025-07-17 16:32
- 网站地址:
“一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案” 网站介绍
(坑给你踩完,可行的结果给你探明,让你的方向明确,存在的小问题自行解决)
1、不要考虑前端转pdf了,我已经帮您爬过坑了。
前端转PDF,本质就是把网页通过canvas转成图片,图片转成PDF。
坑1:PDF文件占内存很大,本来应该是500kb的pdf,直接给你转出20M的pdf。
坑2:PDF很模糊,文字重影,各种控制画质的参数都无法解决。
坑3:PDF中其实就是一张图片,文字无法复制。
2、不要考虑后端PHP转PDF了,我已经帮您爬过坑了。
后端转PDF,本质就是用PHP干HTML的事情。
坑1:PHP去写html那种苦,只有苦命人能吃,特别是遇到JS图表等样式,直接生无可恋。
坑2:PHP去干html的事情无法在浏览器上预览,只有写一下导出pdf看效果,一套开发下来,导几百个pdf,这种苦您能吃不?
坑3:还要求你引入字体包等,麻烦死了。
3、不要考虑后端调用HTML转PDF了,我已经帮您爬过坑了。
后端调用HTML转PDF,本质就是PHP是识别HTML,再转出来。
坑1:大部分HTML不支持,不支持css文件,不支持js等图表,只能写行内样式。
坑2:写出来的浏览器预览效果和导出来的PDF不一致,试着去调样式,再导出pdf看效果,一套开发下来,导几百个pdf,这种苦您能吃不?
今天,亮哥从万坑从中爬出来,为广大劳苦程序猿献上一份:终极解决HTML/CSS/JS网页转PDF(高质量)的终极解决方案,请官人怜惜。
1、准备工作:待转网页、服务器环境。
(1)、待转网页:把你要转出的网页样式,用html、css、js排版出来,不用去在乎兼容性,您能想到的效果都支持。如果您是在网站中弹窗页面预览,网页套在ifram中弹窗即可。
(2)、服务器环境:建议使用傻瓜式维护linux的宝塔,如果您是的linux命令高手也可以不用宝塔。
2、安装wkhtmltopdf:在服务器上安装wkhtmltopdf软件。
安装软件过程中可能会出现各种各样的linux提示报错,因为报错多种多样,我没办法给您一一列举,您根据linux的报错去自行爬文档处理,我这里只给一个我探明可行,可用的思路,你顺着思路走即可。
A、 打开服务器终端。
B、下载wkhtmltopdf复制运行命令:
wget https://github.com/wkhtmltopdf/wkhtmltopdf/releases/download/0.12.5/wkhtmltox-0.12.5-1.centos7.x86_64.rpm
C、安装wkhtmltopdf复制运行命令:
sudo yum localinstall -y wkhtmltox-0.12.5-1.centos7.x86_64.rpm
D、检测wkhtmltopdf是否安装成功,复制运行命令:
wkhtmltopdf -V
3、用PHP创建一个超出的API接口
function PDF()
{
$inputFile = 'https://baidu.com'; //您要转出的网页路径
$outputFile = ROOT_PATH . 'public/uploads/pdf/xxxx.pdf'; //存放PDF的物理路径
$url = '/public/uploads/pdf/xxxx.pdf'; //定义相对路径
$wkhtmltopdfBinary = '/usr/local/bin/wkhtmltopdf --margin-top 5mm --margin-bottom 5mm --margin-left 5mm --margin-right 5mm'; //wkhtmltopdf命令的路
$command = $wkhtmltopdfBinary . ' ' . escapeshellarg($inputFile) . ' ' . escapeshellarg($outputFile); //构建命令
exec($command, $output, $returnCode); //执行命令行
//执行失败暴露错误,用于debug
if ($returnCode !== 0) {
$obj['output']=$output;
$obj['returnCode']=$returnCode;
return $obj;
};
//执行成功,如果有数据库操作,请在下面写你的数据操作
}
}
4、导出效果
写作最后:如果你在操作的过程中遇到问题,私信联系我即可。
更多相关网站
- Aspose.Pdf最新版发布-格式转换更流畅
- Visual Studio Code 扩展介绍 - Markdown转pdf
- 7天从0到上线!手把手教你用Python Flask打造爆款Web服务
- 旗鱼浏览器电脑版v1.01发布:“超级拖拽”等大量新功能等你体验
- C# 使用 iText7 实现 HTML 转 PDF 指南
- 终极 Nginx 配置指南(全网最详细)
- 了解SEO中的Meta机器人标签和X机器人标签
- Linux Mint新版本蓄势待发:揭晓Zara和Gigi、增强Mint-Y主题
- 笔记革命!Obsidian 1.9.0带来结构化管理新体验
- 38个CSS资源升级你的CSS技能(css css)
- DIY从入门到放弃:你真的了解图像格式吗?
- 学前端所用手册及书籍(学前端必备手册全都有)
- web前端学到什么程度就可以找工作了?学到什么程度可以涨薪?
- 最近发表
- 标签列表
-
- mydisktest_v298 (35)
- sql 日期比较 (33)
- document.appendchild (35)
- 头像打包下载 (35)
- 二调符号库 (23)
- acmecadconverter_8.52绿色版 (25)
- 梦幻诛仙表情包 (36)
- 魔兽模型 (23)
- java面试宝典2019pdf (26)
- disk++ (30)
- vncviewer破解版 (20)
- word文档批量处理大师破解版 (19)
- pk10牛牛 (20)
- 加密与解密第四版pdf (29)
- iteye (26)
- parsevideo (22)
- ckeditor4中文文档 (20)
- centos7.4下载 (32)
- cuda10.1下载 (22)
- intouch2014r2sp1永久授权 (33)
- usb2.0-serial驱动下载 (24)
- 魔兽争霸全图 (21)
- jdk1.8.0_191下载 (27)
- axure9注册码 (30)
- gitlab日志 (20)