laravel 中使用的 PDF 扩展包 laravel-dompdf 和 laravel-snappy
这两天项目中需要将HTML页面转换为PDF文件方便打印,我在网上搜了很多资料。先后尝试了laravel-dompdf和laravel-snappy两种扩展包,个人感觉laravel-snappy比较好用。
一、使用laravel-dompdf扩展包
1、安装扩展包
我们通过composer来安装
composer require barryvdh/laravel-dompdf
2、将ServiceProvider添加到config / app.php中的providers数组中
Barryvdh\DomPDF\ServiceProvider::class,
3、添加facade到config / app.php中的aliases数组中
'PDF' => Barryvdh\DomPDF\Facade::class,
4、使用
可以创建一个dompdf实例并加载HTML字符串、文件或者视图,然后使用stream()方法显示在浏览器中、save()方法保存到文件或者download()方法下载。
$pdf = App::make('dompdf.wrapper');
$pdf->loadHTML('<h1>Test</h1>');
return $pdf->stream();
也可以使用门面(facade),使用前先use PDF;
$pdf = PDF::loadView('pdf.invoice', $data);
return $pdf->download('invoice.pdf');
也可以链式操作
return PDF::loadFile(public_path().'/myfile.html')->save('/path-to/my_stored_file.pdf')->stream('download.pdf');
可以更改方向(landscape将方向设为横向,一般使用的都是竖向的,使用时注意一下)和纸张大小,并隐藏或显示错误(默认情况下,调试打开时显示错误)
PDF::loadHTML($html)->setPaper('a4', 'landscape')->setWarnings(false)->save('myfile.pdf')
其他的一些基本使用和配置请参考文档资料:https://github.com/barryvdh/laravel-dompdf
5、解决中文乱码问题
下载一个支持unicode编码的中文字体。例如:msyh.ttf(微软雅黑)
建议先在storage下创建fonts文件夹,把字体放在fonts文件夹下,不然会报错。
在css中引入字体
<style>
@font-face {
font-family: 'msyh';
font-style: normal;
font-weight: normal;
src: url({{ storage_path('your_path/msyh.ttf') }}) format('truetype');
}
body {
font-family: msyh, DejaVu Sans,sans-serif;
}
</style>
注意:亲测只有unicode编码的中文,才能正常显示,这也是我觉得这个PDF扩展不太好用的原因。
二、使用laravel-snappy扩展包
1、安装依赖软件
laravel-snappy扩展包需要Wkhtmltopdff的支持,所以先安装Wkhtmltopdf
方法一:下载wkhtmltopdf安装包
wkhtmltopdf 下载地址:https://wkhtmltopdf.org/downloads.html
windows直接下载安装就可以了,注意安装到你知道的地方,这个路径后面有用。
我的安装在G:wk目录下
在bin目录下有wkhtmltoimage与wkhtmltopdf两个依赖软件
linux下载解压完成后,要将文件移动到 /usr/local/bin 下
方法二:通过 composer 来安装
以linux系统为例
32位:
$ composer require h4cc / wkhtmltopdf-i386 0.12.x
$ composer require h4cc / wkhtmltoimage-i386 0.12.x,
64位:
$ composer require h4cc/wkhtmltopdf-amd64 0.12.x
$ composer require h4cc/wkhtmltoimage-amd64 0.12.x
(uname -a 命令查看系统位数)
cp vendor/h4cc/wkhtmltoimage-amd64/bin/wkhtmltoimage-amd64 /usr/local/bin/
cp vendor/h4cc/wkhtmltopdf-amd64/bin/wkhtmltopdf-amd64 /usr/local/bin/
并使其可执行:
chmod +x /usr/local/bin/wkhtmltoimage-amd64
chmod +x /usr/local/bin/wkhtmltopdf-amd64
Linux 下使用该第三方插件需要几个库的支持
yum install libXrender*
yum install libfontconfig*
2、安装laravel-snappy扩展包
composer require barryvdh/laravel-snappy
3、将ServiceProvider添加到config / app.php中的providers数组
Barryvdh\Snappy\ServiceProvider::class,
4、添加facade到config / app.php中的aliases数组中
'PDF' => Barryvdh\Snappy\Facades\SnappyPdf::class,
'SnappyImage' => Barryvdh\Snappy\Facades\SnappyImage::class,
5、生成配置文件
高版本的 laravel ,例如 Version 5.5 以上,请忽略上面的3,4步骤,直接到这里生成皮配置文件
php artisan vendor:publish --provider="Barryvdh\Snappy\ServiceProvider"
此命令会在 config/snappy.php 生成配置文件
具体配置如下:
<?php
return [
'pdf' => [
'enabled' => true,
'binary' => env('WKHTML_PDF_BINARY', '/usr/local/bin/wkhtmltopdf-amd64'), // linux 配置路径
// 'binary' => env('WKHTML_PDF_BINARY', 'G:\wk\wkhtmltopdf\bin\wkhtmltopdf\wkhtmltopdf-amd64'), // windows 配置路径
'timeout' => false,
'options' => [],
'env' => [],
],
'image' => [
'enabled' => true,
'binary' => env('WKHTML_IMG_BINARY', '/usr/local/bin/wkhtmltoimage-amd64'), // linux 配置路径
// 'binary' => env('WKHTML_IMG_BINARY', 'G:\wk\wkhtmltopdf\bin\wkhtmltopdf\wkhtmltoimage-amd64'), // windows 配置路径
'timeout' => false,
'options' => [],
'env' => [],
],
];
6、使用 ( 与使用dompdf类似 )
先引入
use PDF;
use SnappyImage;
生成PDF文件
可以使用门面(facade)加载HTML字符串、文件或者视图,然后使用stream()方法显示在浏览器中、save()方法保存到文件或者download()方法下载。
$pdf = PDF::loadView('pdf.invoice', $data);
return $pdf->download('invoice.pdf');
也可以链式操作
return PDF::loadFile(public_path().'/myfile.html')->save('/path-to/my_stored_file.pdf')->stream('download.pdf');
可以更改方向(landscape将方向设为横向,一般使用的都是竖向的,使用时注意一下)和纸张大小,并隐藏或显示错误(默认情况下,调试打开时显示错误)
PDF::loadHTML($html)->setPaper('a4', 'landscape')->setWarnings(false)->save('myfile.pdf')
生成图片
$pdf = SnappyImage::loadView('pdf.invoice', $data);
return $pdf->download('invoice.image');
7、解决中英文乱码问题 (linux)
方法一:
宋体或其他中文字体添加到 /usr/share/fonts/ 里
方法二:
安装中文字体:
yum install ipa-gothic-fonts ipa-mincho-fonts ipa-pgothic-fonts ipa-pmincho-fonts
在方法里面转义为 utf-8
$pdf -> setOption('encoding', 'utf-8');
Demo测试用例如下:
Controller 层
<?php
namespace App\Http\Controllers\V2;
use Illuminate\Http\Request;
use App\Responses\Res;
use Illuminate\Support\Facades\Validator;
use PDF;
use SnappyImage;
use App;
use Illuminate\Support\Facades\Response;
class PdfController extends Controller
{
/**
* 您可以创建一个新的Snappy PDF / Image实例并加载HTML字符串,文件或视图名称。您可以将其保存到文件中,也可以内联(在浏览器中显示)或下载。
* 使用App容器:
*/
public function pdf1()
{
$snappy = App::make('snappy.pdf');
//To file
$html = '<h1>Bill</h1><p>You owe me money, dude.</p>';
$snappy->generateFromHtml($html, '/tmp/bill-123.pdf');
$snappy->generate('http://www.github.com', '/tmp/github.pdf');
//Or output:
return new Response(
$snappy->getOutputFromHtml($html),
200,
array(
'Content-Type' => 'application/pdf',
'Content-Disposition' => 'attachment; filename="file.pdf"'
)
);
}
/**
* 使用包装器:
*
* 使用内嵌的 html 生成一个pdf文件,然后进行 online 的预览
*/
public function pdf2()
{
$pdf = App::make('snappy.pdf.wrapper');
$pdf->setOption('encoding', 'utf-8');
$pdf->loadHTML('<h1>Test-中文</h1>');
return $pdf->inline();
}
/**
* 或使用外观:
*
* 使用 blade 模板引擎,生成 pdf 文件
*/
public function pdf3()
{
$pdf = PDF::loadView('v2.pdf.view_test', array(
'h1' => 'English Test',
'h2' => 'Test Number123456',
'h3' => '测试中文',
));
$pdf->setOption('encoding', 'utf-8');
return $pdf->download('invoice.pdf');
}
/**
* 您可以链接方法:
*
* 用过 url 网址获取内容,然后生成pdf文件
*/
public function pdf4()
{
return PDF::loadFile('https://www.baidu.com/')->inline('github.pdf');
}
/**
* 您可以更改方向和纸张尺寸
*/
public function pdf5()
{
$html = '<h1>11111</h1><h2>Test</h2><h3>份打散加啦</h3>';
PDF::loadHTML($html)->setPaper('a4')->setOrientation('landscape')->setOption('margin-bottom', 0)->save('myfile.pdf');
}
/**
* 图片生成
*
* 利用 blade 模板,生成文件
*/
public function img1()
{
$pdf = SnappyImage::loadView('v2.pdf.view_test', array(
'h1' => 'English Test',
'h2' => 'Test Number123456',
'h3' => '测试中文,和标点符号',
));
$pdf->setOption('encoding', 'utf-8');
return $pdf->stream('image.jpg'); // 实现预览用此方法
// return $pdf->download('invoice.image.jpg'); // 实现下载用此方法
}
}
View层(v2.pdf.view_test):
<h1>{{$h1}}</h1>
<h2>{{$h2}}</h2>
<h3>{{$h3}}</h3>
更多设置
$pdf = App::make('snappy.pdf.wrapper');
return $pdf
//->loadHtml('<h1>你好123</h1>')
//->loadFile('http://www.kissyou.club/wap/parttime-job/')
->loadView('test.index')
->setPaper('a4')
->setOrientation('landscape')
->setOption('margin-bottom', 0)
->setOption('enable-forms', true)
//->setOption('grayscale', true)
//->setOption('debug-javascript', true)
//->setOption('page-offset', 8)
->setOption('encoding', 'utf-8')
//->setOption('header-font-name', 'msyh')
//->setOption('enable-external-links', true)
->inline(); // $data 为传递的参数
//return $pdf->inline(); // 显示
参考资料如下:
laravel-dompdf包: https://packagist.org/packages/barryvdh/laravel-dompdf
laravel-snappy包:https://packagist.org/packages/barryvdh/laravel-snappy
原作者:https://www.cnblogs.com/weiyalin/articles/7765558.html
laravel 中使用的 PDF 扩展包 laravel-dompdf 和 laravel-snappy的更多相关文章
- laravel中使用的PDF扩展包——laravel-dompdf和laravel-snappy
这两天项目中需要将HTML页面转换为PDF文件方便打印,我在网上搜了很多资料.先后尝试了laravel-dompdf和laravel-snappy两种扩展包,个人感觉laravel-snappy比较好 ...
- 在 Laravel 中通过 Artisan View 扩展包创建及删除应用视图文件
1.简介 本扩展包添加了两个视图相关的Artisan命令到Laravel应用,以便我们通过Artisan命令即可创建和管理视图文件,可谓是进一步解放了生产力. 2.安装 还是通过Composer安装: ...
- laravel框架应用和composer扩展包开发
laravel5.5+ laravel官方地址 laravel是目前最流行的php框架,发展势头迅猛,应用非常广泛,有丰富的扩展包可以应付你能想到的各种应用场景,laravel框架思想前卫,跟随时代潮 ...
- Laravel / PHP 扩展包视频教程
https://laravel-china.org/courses/laravel-package 每周精选两个以上扩展包进行讲解,涵盖 PHP 和 Laravel 相关的最新.最热.最常用的扩展包. ...
- Laravel 调试利器 —— Laravel Debugbar 扩展包安装及使用教程
1.简介 Laravel Debugbar 在 Laravel 5 中集成了 PHP Debug Bar ,用于显示调试及错误信息以方便开发.该扩展包包含了一个 ServiceProvider 用于注 ...
- laravel composer 扩展包开发(超详细)
laravel composer 扩展包开发(超详细) 置顶 2018年02月05日 11:09:16 Simael__Aex 阅读数:10396 版权声明:转载请注明出处:http://blo ...
- Laravel 中使用 JWT 认证的 Restful API
Laravel 中使用 JWT 认证的 Restful API 5天前/ 678 / 3 / 更新于 3天前 在此文章中,我们将学习如何使用 JWT 身份验证在 Laravel 中构建 r ...
- laravel 中CSS 预编译语言 Sass 快速入门教程
CSS 预编译语言概述 CSS 作为一门样式语言,语法简单,易于上手,但是由于不具备常规编程语言提供的变量.函数.继承等机制,因此很容易写出大量没有逻辑.难以复用和扩展的代码,在日常开发使用中,如果没 ...
- laravel中的验证及利用uploadify上传图片
$rules = [ 'password'=>'required|between:6,20|confirmed', ]; $message = [ 'password.required'=> ...
- Laravel中我们登录服务器通过 Tinker 手动创建后台管理用户
Laravel中我们可以登录到服务器通过 Tinker 手动创建后台用户 laravel中tinker命令的作用是用来调试laravel,可以打印变量或对象信息,显示函数代码,对数据库写入和查询数据. ...
随机推荐
- k8s重启应用
[root@k8s-master01 opt_k8s]# cat app_list xxx-supervise-srv xxx-recon-srv xxx-mkt-strategy-srv xxx-u ...
- web自动化测试—Firefox安装与配置
web自动化测试-Firefox安装与配置 下一步 下一步 下一步 下一步 下一步 下一步 下一步 下一步 下一步设置不更新 下一步添加插件 下一步 下一步 下一步 下一步立即重启 下一步查看插件 在 ...
- js数组原型方法
今天学习了一下js数组原型的操作方法,小结一下学习地址https://www.cnblogs.com/obel/p/7016414.html 1.join() join(separator): 将数组 ...
- 11、jmeter配置元件--计数器
前面学过csv和变量 csv里面的数据是固定的 如果里面的数据不够 线程要么就停止要么就需要重头再来 不太灵活 用到固定化的数据,比如说多少个用户等等 如果有一些是变动的 随着线程数增加 数据 ...
- CGAL的demo运行的步骤
首先使用CMake,找到demo的源文件目录,并且指定生成文件目录: 点击configur,done 点击generate,done 找到build目录中的.sln 文件,打开 ALL_BUILD 生 ...
- CSS3之伸缩布局
一 主轴方向 在伸缩布局中, 默认伸缩项是从左至右的排版的 主轴的排版的方向默认就是row, 默认就是从左至右 1.默认情况下主轴是水平方向的, 但是也可以修改为垂直方向.只要看到flex-direc ...
- win10edge浏览器个人账户退出登录后再次登录自动登录问题
edge浏览器退出登录后,再次点击登录以同步数据会自动登录,可查看书签等个人数据 解决方法: 先在浏览器里面退出账户. 1.设置--电子邮件和账户--管理 2.登录后--安全--安全仪表板--高级安全 ...
- Action: Consider the following: If you want an embedded database (H2, HSQL or Derby), please put it on the classpath.
错误原因 在pom中引入了mybatis-spring-boot-starter ,Spring boot默认会加载org.springframework.boot.autoconfigure.jdb ...
- 观察APP运行日志
一.Android采用log工具打印日志,他将各类日志分为五个等级 1.log.e:表示错误信息,比如可能导致程序崩溃的异常 2.log.w:表示警告信息 3.log.i:表示一般信息 4.log.d ...
- vue项目 - 自定义数字输入指令 | 限制自定义小数位输入
1.在main.js中直接加入代码: import Vue from 'vue' Vue.directive("input-limit", { bind(el, binding) ...