网站首页 > 技术文章 正文
(坑给你踩完,可行的结果给你探明,让你的方向明确,存在的小问题自行解决)
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、导出效果
写作最后:如果你在操作的过程中遇到问题,私信联系我即可。
猜你喜欢
- 2024-10-06 ?? JavaScript提取PDF图片 ?? js 导出pdf
- 2024-10-06 VUE前端编程:PDF插件填坑记 vue-to-pdf
- 2024-10-06 把HTML转成PDF的4个方案及实现方法
- 2024-10-06 使用reveal.js制作精美的网页版PPT
- 2024-10-06 硬核!《web前端开发规范手册》,高清版 PDF 开放下载,拿走不谢
- 2024-10-06 让 PDF文档看起来像扫描的一样 pdf变成扫描版
- 2024-10-06 阿里架构师花近十年时间整理出来的前端核心知识pdf(前端岗)
- 2024-10-06 基于springboot的多格式转PDF springboot word转pdf
- 2024-10-06 Java后端实现HTML网页报表导出pdf方案
- 2024-10-06 原来Word转PDF是那么简单,1分钟即可搞定!你现在还不会吗?
你 发表评论:
欢迎- 501℃几个Oracle空值处理函数 oracle处理null值的函数
- 497℃Oracle分析函数之Lag和Lead()使用
- 495℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 482℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 478℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 468℃【数据统计分析】详解Oracle分组函数之CUBE
- 454℃Oracle有哪些常见的函数? oracle中常用的函数
- 450℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 最近发表
-
- Directus 火了!无代码 SQL 数据的协作应用利器!
- PHP和NodeJS的代码执行效率比较(php和nodejs的区别)
- 工商银行获得发明专利授权:“基于数据库映射动态接口的前端页面应用开发方法及装置”
- FAISS和Chroma:两种流行的向量数据库的比较
- 什么是数据库的索引?(数据库索引的定义和作用)
- Vercel和Neon“首次”推出用于前端云的无服务器SQL数据库
- 记一次前端逻辑绕过登录到内网挖掘
- 学Access好还是MySQL好?(access与mysql的语句区别)
- 惬意!清晨慢品 HTML canvas 标签题,面试知识轻松 get
- 前端实现知识图谱-force(d3.js)(前端知识树)
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端富文本编辑器 (47)
- 前端路由 (55)
- 前端数组 (65)
- 前端定时器 (47)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle链接 (47)
- oracle的函数 (57)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)