设为首页 收藏本站
查看: 1016|回复: 0

[经验分享] php将html转为图片

[复制链接]

尚未签到

发表于 2017-12-30 07:08:10 | 显示全部楼层 |阅读模式
  在服务器端解析将编译好的html转换为图片。
  由于html一般由客户端浏览器解析,服务器端不能直接解析html代码。所以我们需要借助php类库及扩展完成这一需求。
  文件转换过程为 html —> pdf —>png。
  需要借助的类库是mPDF ,imagick
  pdf 官方下载地址是:http://www.mpdf1.com/mpdf/index.php (推荐下在6.0 虽然大了点)这是一个类库直接下载 上传到服务器即可,里面东西不少,新建一个 html2pdf 的文件夹 引入
  

include('./html2pdf/mpdf');  

  

  
整一个函数
  

  

/*  
名称      html转换为pdf图片
  
功能      将html页面转换为pdf图片(部分css样式无法识别)
  
参数数量  2个
  
1.必须    html代码 可以用file_get_contenth获取
  
2.必须    生成pdf存放位置路径
  
3.非必须  pdf宽
  
4.非必须  pdf高
  
返回值    图片名称
  
实例      code($html,'img/1.pdf');
  
*
*/  
function html2pdf($html, $PATH, $w=414 ,$h=736){
  
//设置中文字体(很重要 它会影响到第二步中 图片生成)
  
$mpdf=new mPDF('utf-8');
  
$mpdf->autoScriptToLang = true;
  
$mpdf->autoLangToFont = true;
  
//设置pdf的尺寸
  
$mpdf->WriteHTML('<pagebreak sheet-size="'.$w.'mm '.$h.'mm" />');
  

  

  
//设置pdf显示方式
  
$mpdf->SetDisplayMode('fullpage');
  

  
//删除pdf第一页(由于设置pdf尺寸导致多出了一页)
  
$mpdf->DeletePages(1,1);
  

  
$mpdf->WriteHTML($html);
  

  
$pdf_name = md5(time()).'.pdf';
  

  
$mpdf->Output($PATH.$pdf_name);
  

  
return $pdf_name;
  

  
}
  

  

  

  用这个函数基本就可以解决HTML到pdf的问题,需要注意的是mpdf并不能有效的识别html中所有的css样式,例如position border-radius等。位置可以用margin解决,需要显示圆角图片的话,就需要将图片裁剪为圆形了。
  接下来开始将pdf转换为png图片了这一步需要在服务器安装ImageMagick组件 一次运行一下命令
  

yum install -y ImageMagick  
yum install
-y ImageMagick-devel  
yum install
-y gcc  
yum install
-y php-pear  
yum install
-y ghostscript  
yum install
-y ghostscript-devel.x86_64  

  

  

  到这一步注意运行
  

yum list |grep imagick  

  根据查询结果 根据自己服务器版本 选择安装 我的是5.6.3
  

yum install -y php56w-pecl-imagick.x86_64  
yum install
-y php56w-pecl-imagick-devel.x86_64  

  重启服务器
  

service nginx restart  
service php
-fpm restart  

  使用 phpinfo() 或运行 php -m | grep imagick 来查看是否安装成功
  然后使用函数将已经生成的pdf转换为png就可以了
  

/*  
名称      pdf转换为png图片
  
功能      将pdf图片转换为png图片
  
参数数量  2个
  
1.必须    html代码 可以用file_get_contenth获取
  
2.必须    生成pdf存放位置路径
  

  
实例      code($html,'img/1.pdf');
  
*
*/  
function pdf2png($PDF, $PNG, $w=50, $h=50){
  
if(!extension_loaded('imagick')){
  
return false;
  
}
  
if(!file_exists($PDF)){
  
return false;
  
}
  

  
$im = new Imagick();
  

  
$im->setResolution($w,$h); //设置分辨率
  
$im->setCompressionQuality(15);//设置图片压缩的质量
  

  
$im->readImage($PDF);
  
$im -> resetIterator();
  
$imgs = $im->appendImages(true);
  
$imgs->setImageFormat( "png" );
  
$img_name = $PNG;
  
$imgs->writeImage($img_name);
  
$imgs->clear();
  
$imgs->destroy();
  
$im->clear();
  
$im->destroy();
  

  
return $img_name;
  
}
  

  ok,基本完成简单页面的图片化了。图片大小为1M左右。小了不清楚。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-429558-1-1.html 上篇帖子: php 二维数组去重 下篇帖子: PHP命名空间的作用、为什么使用命名空间?
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表