php将html转为图片的实现方法
在服务器端解析将编译好的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'); **/ functionhtml2pdf($html,$PATH,$w=414,$h=736){ //设置中文字体(很重要它会影响到第二步中图片生成) $mpdf=newmPDF('utf-8'); $mpdf->autoScriptToLang=true; $mpdf->autoLangToFont=true; //设置pdf的尺寸 $mpdf->WriteHTML(''); //设置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样式,例如positionborder-radius等。位置可以用margin解决,需要显示圆角图片的话,就需要将图片裁剪为圆形了。
接下来开始将pdf转换为png图片了这一步需要在服务器安装ImageMagick组件一次运行一下命令
yuminstall-yImageMagick yuminstall-yImageMagick-devel yuminstall-ygcc yuminstall-yphp-pear yuminstall-yghostscript yuminstall-yghostscript-devel.x86_64
到这一步注意运行
yumlist|grepimagick
根据查询结果根据自己服务器版本选择安装我的是5.6.3
yuminstall-yphp56w-pecl-imagick.x86_64 yuminstall-yphp56w-pecl-imagick-devel.x86_64
重启服务器
servicenginxrestart servicephp-fpmrestart
使用phpinfo()或运行php-m|grepimagick来查看是否安装成功
然后使用函数将已经生成的pdf转换为png就可以了
/* 名称pdf转换为png图片 功能将pdf图片转换为png图片 参数数量2个 1.必须html代码可以用file_get_contenth获取 2.必须生成pdf存放位置路径 实例code($html,'img/1.pdf'); **/ functionpdf2png($PDF,$PNG,$w=50,$h=50){ if(!extension_loaded('imagick')){ returnfalse; } if(!file_exists($PDF)){ returnfalse; } $im=newImagick(); $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左右。小了不清楚。
以上这篇php将html转为图片的实现方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。