0

0

在 Laravel 中生成 PDF 文档

王林

王林

发布时间:2024-07-15 10:37:01

|

831人浏览过

|

来源于dev.to

转载

在 laravel 中生成 pdf 文档

laravel 和 dompdf:使用图像和 css 生成 pdf 文档的分步指南

创建 pdf 文档是 web 应用程序中的常见需求,尤其是生成发票、收据、证书、票据和各种报告。在这个综合教程中,我们将深入研究如何使用 laravel 和 dompdf 生成带有图像和 css 的 pdf 文档。我们将介绍配置选项、设计注意事项、输出大小、性能和数据库查询。此外,我们还将讨论处理分页符、使用 base64 加载图像等的提示和技巧。

先决条件

在我们开始之前,请确保您已安装以下软件:

  • php >=8.2
  • 作曲家2+
  • laravel 10+

介绍

dompdf 是一个流行的 php 库,允许您从 html 内容生成 pdf 文档。它支持 css 样式、图像和各种配置选项。通过将 dompdf 与 laravel 集成,您可以使用 blade 模板和 laravel 的强大功能轻松创建复杂的 pdf 文档。

其他流行的 pdf 库包括 tcpdf、fpdf 和 snappy。

然而,dompdf 由于其易于集成和强大的功能集而被广泛使用。

在本教程中,我们将逐步介绍设置 laravel 项目、配置 dompdf、创建处理 pdf 生成的控制器、为 pdf 内容设计 blade 模板、添加路由和优化性能的过程。我们还将讨论高级配置选项,并提供生成高质量 pdf 文档的提示和技巧。

假设

本教程假设您对 laravel 和 php 有基本的了解。如果您是 laravel 新手,请考虑阅读官方 laravel 文档来熟悉该框架。否则,您可以按照 laravel bootcamp 开始使用 laravel。

第 1 步:设置 laravel 项目

首先,如果你还没有 laravel 项目,请创建一个新的 laravel 项目,或者使用现有的项目,当然,如果你已经有 laravel 项目,你可以跳过这一步。

composer create-project --prefer-dist laravel/laravel pdf-tutorial
cd pdf-tutorial

接下来,安装dompdf:

composer require barryvdh/laravel-dompdf

发布配置文件:

php artisan vendor:publish --provider="barryvdh\dompdf\serviceprovider"

第2步:配置dompdf

打开config/dompdf.php 文件。配置文件包含用于自定义 pdf 输出的各种选项。在这里您可以设置各种选项,包括默认纸张尺寸、方向、字体等。

  • 纸张尺寸: 您可以设置默认纸张尺寸。
  'default_paper_size' => 'a4',
  • 方向: 设置默认方向(纵向或横向)。
  'orientation' => 'portrait',
  • 字体: 您可以指定默认字体并添加自定义字体。
  'default_font' => 'serif',

第三步:创建控制器

创建一个控制器来处理 pdf 生成:

php artisan make:controller pdfcontroller

在 app/http/controllers/pdfcontroller.php 中,添加以下代码:

<?php

namespace app\http\controllers;

use illuminate\http\request;
use pdf;

class pdfcontroller extends controller
{
    public function generatepdf()
    {
        $data = [
            'title' => 'laravel pdf example',
            'date' => date('m/d/y'),
        ];

        $pdf = pdf::loadview('mypdf', $data);

        return $pdf->download('document.pdf');
    }
}

第 4 步:创建刀片模板

为 pdf 内容创建 blade 模板:

touch resources/views/mypdf.blade.php

在 mypdf.blade.php 中添加以下内容:

阿里云AI平台
阿里云AI平台

阿里云AI平台

下载
<!doctype html>
<html>
<head>
    <title>laravel pdf example</title>
    <style>
        body {
            font-family: 'arial, sans-serif';
        }
        .container {
            margin: 0 auto;
            padding: 20px;
        }
        .header {
            text-align: center;
            margin-bottom: 20px;
        }
        .content {
            font-size: 12px;
        }
    </style>
</head>
<body>
    <div class="container">
        <div class="header">
            <h1>{{ $title }}</h1>
            <p>date: {{ $date }}</p>
        </div>
        <div class="content">
            <p>this is an example of a pdf document generated using laravel and dompdf.</p>
        </div>
    </div>
</body>
</html>

第5步:添加路由

在routes/web.php中添加处理pdf生成的路由:

use app\http\controllers\pdfcontroller;

route::get('generate-pdf', [pdfcontroller::class, 'generatepdf']);

第 6 步:添加图像

您可以通过将图像嵌入为 base64 编码字符串或使用 url 来将图像添加到 pdf。

图像可以使用base64编码直接嵌入到blade模板中。例如,要嵌入来自公共/图像的图像,您可以这样做:

<img src="data:image/png;base64,{{ base64_encode(file_get_contents(public_path('images/logo.png'))) }}" alt="logo">

或直接从网址:

<img src="{{ asset('images/logo.png') }}" alt="logo">

第 7 步:优化性能

数据库查询

处理大型数据集(例如 1,000 多条记录)时,使用分页或分块来管理内存使用:

$data = db::table('users')->paginate(50);

$pdf = pdf::loadview('mypdf', ['data' => $data]);

输出尺寸

为了减少输出大小,请尽量减少使用大量图像,并尽可能选择矢量图形。另外,使用高效的 css。

分页符

确保内容结构良好,适合分页。使用 css 处理分页符:

.page-break {
    page-break-after: always;
}

在你的 blade 模板中:

<div class="page-break"></div>

步骤8:高级配置

更高级的配置请参考dompdf文档。您可以自定义几乎所有内容,从边距到字体加载方式。

使用自定义字体

要使用自定义字体,首先将它们添加到您的项目中并配置 dompdf 以使用它们:

'custom_font_dir' => base_path('resources/fonts/'),
'custom_font_data' => [
    'custom-font' => [
        'r' => 'customfont-regular.ttf',
        'b' => 'customfont-bold.ttf',
    ]
],

在您的 blade 模板中:

<style>
    body {
        font-family: 'custom-font', sans-serif;
    }
</style>

结论

按照此分步指南,您可以使用 laravel 和 dompdf 生成复杂的 pdf 文档,并包含图像和 css 样式。本教程涵盖了基本的配置选项、设计注意事项、性能优化。您可以扩展此基础,为您的 laravel 应用程序构建强大的文档生成系统。

潜在系列和存储库

本教程是使用 laravel 生成 pdf 系列的一部分。可以在此处找到包含各种文档模板(发票、收据、证书、票据等)的完整存储库。请随意贡献并扩大收藏。

快乐编码!

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

340

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

293

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

773

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

385

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

141

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

85

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

80

2025.08.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

571

2026.03.04

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 42.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号