相关文章推荐
爱看球的太阳  ·  /usr/include/c++/8/cst ...·  1 年前    · 
耍酷的书包  ·  singularity install ...·  1 年前    · 
光明磊落的毛巾  ·  sqlite中的# ...·  1 年前    · 

解决PHP使用MPDF,图片不显示问题。

1. MPDF使用:

简单介绍:使用composer 安装
在composer.json文件中,加上 "mpdf/mpdf": "^8.0" ,删除原有的composer.lock文件,重新 composer install
在这里插入图片描述

2. 在项目中使用:

因为项目是前后端分离,所以我将的pdf文件先保存到本地,再将本地文件上传到七牛云网盘中,再将网盘返回的url,以json格式返回给前端,前端通过url即可展示预览地址。

//1、F服务器保存以$path为名称的文件。2、D浏览器下载以$path为名称的文件。3、S以字符串形式返回 $path忽略。4、浏览器展示,但当用户另存为时以$path为默认文件名

3. 出现问题及如何排查图片问题:

出现的问题:

可以明显的看到文本可以正常显示,但是中间的图片无法显示。后面经过排查发现:jpg图片可以正常显示,但是png图片文法显示。
在这里插入图片描述

如何排查:

我们可以从MPDF官方文档中找到:
调试错误:如果图像无法正确显示时遇到问题,请设置变量 。$mpdf->showImageErrors = true
在这里插入图片描述
在这里插入图片描述

不知道怎么加的,可以看上面的:项目使用中的图片,我已经加上了错误排查。
加上了排查之后 ,再调用接口 就可以看到错误信息。
在这里插入图片描述
问题原因:提示GD库没有png支持

4. 解决问题:

  • 去服务器上打开gd扩展。通过php -m可以看到gd 则表示gd扩展已经开启。
    在这里插入图片描述

  • 查看gd扩展 png是否支持。通过 php --ri gd 查看gd扩展的信息。下图表示png 已经支持。
    在这里插入图片描述

  • 配置好之后,一定要重启fpm。kill -USR2 fpm进程的pid 平滑重启
    在这里插入图片描述

5. 验证是否解决。

传递png图片,通过返回的预览地址,在浏览器打开,即可看到图片可以正常显示。
在这里插入图片描述

mPDF是一个很强大的PDF生成库,能基本兼容HTML标签和CSS3样式,这篇文章通过实例代码给大家介绍PHP使用mpdf 导出PDF文件的实现方法。 具体代码如下所示: * PHP 使用 mpdf 导出PDF文件 * @param $content string PDF文件内容 若为html代码,css内容分离 非id,class选择器可能失效,解决办法直接写进标签style中 * @param $filename string 保存文件名 * @param $css string css样式内容 function export_pdf_by_mpdf($c
由于公司业务的需要,最近需要把html静态文件生成pdf,在网上找了很多类文件来实现,效果都不是很好.最先用的是tcpdf这个类特别的慢,而且当前版本有一个很让人头疼的问题—css中的背景图片无法获取到,找了很多资料都无法解决.最后发现mpdf可能实现该功能,大喜过望,而且效率也比tcpdf快. mpdf的官方下载地址:http://www.mpdf1.com/mpdf/download 下载后里面有实例,可以参照着做一个就知道了.当然官方网站也有实例,网址:http://mpdf1.com/common/mpdf/examples/ 官方提供的文档:http://mpdf1.com/ma
主要需求是将html页面转换为pdf文档1、安装mpdf工具类 (composer方式)2、控制器里调用3、效果如下图 1、安装mpdf工具类 (composer方式) composer require mpdf/mpdf:8.0.3 2、控制器里调用 use Mpdf\Mpdf; $this->test_pdf(); public function test_pdf() $mpdf = new Mpdf([ 'mode' => 'UTF-8', 'format' =&
这里写自定义目录标题欢迎使用Markdown编辑器新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants创建一个自定义列表如何创建一个注脚注释也是必不可少的KaTeX数学公式新的甘特图功能,丰富你的文章UML 图表FLowchart流程图导出与导入导出导入 欢迎使用Markdown编辑器 你好! 这是你第一次使用 Markdown编辑器 所展示的欢迎页。如果你想学习如何使用Mar
首先检查了php扩展是否正常。其实不认为这个有问题。不过还是先检查一下。包括相关依赖软件包都正常。 然后对各种图片格式进行了测试。发现无论是png还是jpg,都会有部分图片无法显示。反过来说,都会有部分图片可以显示。 怀疑是否因为图片太大导致读取失败。目前使用图片都是比较小的图片正常,较大的不显示(其实最大的图片也 require_once __DIR__ . '/vendor/autoload.php'; // 引入 mPDF 类库 $mpdf = new \Mpdf\Mpdf([ 'mode' => 'utf-8', 'format' => 'A4', 'font-family' => 'Arial', 'font-size' => '12pt', 3. 生成 PDF 文件内容 将对话记录的内容按照一定的格式输出到 PDF 文件中。 // 假设对话记录保存在一个数组中,每条记录包含时间戳和对话内容 $conversation = [ ['timestamp' => '2021-01-01 10:00:00', 'content' => '你好'], ['timestamp' => '2021-01-01 10:01:00', 'content' => '你好,有什么可以帮您?'], // ... $html = '<table>'; foreach ($conversation as $msg) { $html .= '<tr>'; $html .= '<td>' . $msg['timestamp'] . '</td>'; $html .= '<td>' . $msg['content'] . '</td>'; $html .= '</tr>'; $html .= '</table>'; $mpdf->WriteHTML($html); 4. 输出 PDF 文件 将 PDF 文件保存到本地或输出到浏览器。 $mpdf->Output('conversation.pdf', 'D'); 以上是使用 mPDF 生成对话记录的 PDF 文件的基本步骤,具体实现可以根据需求进行调整。