0

0

如何使用 PHP 基于上传的 PDF 模板动态生成新 PDF 文件

花韻仙語

花韻仙語

发布时间:2026-02-02 12:05:26

|

947人浏览过

|

来源于php中文网

原创

如何使用 PHP 基于上传的 PDF 模板动态生成新 PDF 文件

本文介绍如何在 php 中利用 fpdi 库,将用户上传的 pdf 作为模板,动态填充或叠加内容并生成新的 pdf 文件,适用于合同、证书、报表等场景。

在 PHP 开发中,若需基于用户上传的 PDF 模板(如已设计好的合同、发票或证书)生成个性化 PDF,直接修改原始 PDF 内容不可行——因为 PDF 是静态格式,不支持原生文本插入。此时,推荐使用 FPDI(Free PDF Importer)配合 TCPDFFPDF 实现“模板复用”:FPDI 负责导入并定位模板页面,再通过底层绘图 API 叠加文字、图像等动态内容。

✅ 推荐技术:FPDI + FPDF(轻量可靠)

FPDI 是一个成熟、开源且无需外部依赖的 PHP 库,专为导入现有 PDF 页面而设计。它不修改源文件,而是将其作为背景“画布”,再调用 FPDF 的 Cell()、MultiCell()、Image() 等方法在指定坐标写入动态数据。

? 快速上手示例

以下代码演示如何加载本地 PDF 模板(如 template.pdf),在第一页右上角添加客户姓名,并输出浏览器下载:

魔法映像企业网站管理系统
魔法映像企业网站管理系统

技术上面应用了三层结构,AJAX框架,URL重写等基础的开发。并用了动软的代码生成器及数据访问类,加进了一些自己用到的小功能,算是整理了一些自己的操作类。系统设计上面说不出用什么模式,大体设计是后台分两级分类,设置好一级之后,再设置二级并选择栏目类型,如内容,列表,上传文件,新窗口等。这样就可以生成无限多个二级分类,也就是网站栏目。对于扩展性来说,如果有新的需求可以直接加一个栏目类型并新加功能操作

下载
setSourceFile($templatePath);

// 导入第一页(MediaBox 坐标系)
$tplId = $pdf->importPage(1, PdfReader\PageBoundaries::MEDIA_BOX);

// 添加新页面(尺寸与模板一致)
$pdf->addPage();
$pdf->useImportedPage($tplId, 0, 0, 0, 0); // 全页铺满

// 在坐标 (100, 50) 处添加动态文本(单位:mm)
$pdf->SetFont('Helvetica', '', 12);
$pdf->SetTextColor(0, 0, 0);
$pdf->SetXY(100, 50);
$pdf->Cell(0, 10, '客户姓名:张三', 0, 1);

// 输出 PDF(I=inline 浏览器预览;D=强制下载)
$pdf->Output('D', 'filled-contract.pdf');
?>
? 关键说明: $_FILES['template_file']['tmp_name'] 即前端 上传后的临时路径,务必先校验文件类型(mime == application/pdf)和大小; useImportedPage() 的后四个参数为 x, y, width, height,设为 0,0,0,0 表示按原始尺寸居左上角放置; 若需精确对齐(如填写表单字段),建议用 Adobe Acrobat 测量目标位置的 X/Y 坐标(单位 mm),再传入 SetXY()。

⚠ 注意事项与最佳实践

  • 安全第一:严禁直接使用用户上传的文件名构造路径(防路径遍历)。应生成唯一随机名(如 uniqid().'.pdf'),并保存至非 Web 可访问目录;
  • 模板限制:FPDI 仅支持 PDF 1.4 及以下版本;加密 PDF 需先解密(FPDI 不支持密码解析);
  • 中文支持:默认字体不支持中文。如需显示中文,请改用 TCPDF + addTTFfont() 加载 .ttf 字体,或选用支持 UTF-8 的 mpdf(但 mpdf 对复杂模板兼容性略弱);
  • 性能提示:大批量生成时,避免频繁 new Fpdi(),可复用实例或改用队列异步处理。

✅ 替代方案简析

方案 适用场景 备注
FPDI + TCPDF 需要丰富排版/中文/HTML 转 PDF 功能强但体积大,学习成本略高
mPDF 模板含 HTML/CSS,需快速渲染 支持 writeHTML(),但 PDF 模板导入能力不如 FPDI 稳定
Dompdf 纯 HTML 模板优先 不支持导入现有 PDF,仅适合从零生成

掌握 FPDI 后,你即可构建可靠的 PDF 模板引擎——无论是电子签章前置、学生成绩单批量生成,还是个性化营销物料输出,都能以极小开销实现专业级交付。

立即学习PHP免费学习笔记(深入)”;

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

399

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

577

2023.08.10

点击input框没有光标怎么办
点击input框没有光标怎么办

点击input框没有光标的解决办法:1、确认输入框焦点;2、清除浏览器缓存;3、更新浏览器;4、使用JavaScript;5、检查硬件设备;6、检查输入框属性;7、调试JavaScript代码;8、检查页面其他元素;9、考虑浏览器兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

187

2023.11.24

AO3官网入口与中文阅读设置 AO3网页版使用与访问
AO3官网入口与中文阅读设置 AO3网页版使用与访问

本专题围绕 Archive of Our Own(AO3)官网入口展开,系统整理 AO3 最新可用官网地址、网页版访问方式、正确打开链接的方法,并详细讲解 AO3 中文界面设置、阅读语言切换及基础使用流程,帮助用户稳定访问 AO3 官网,高效完成中文阅读与作品浏览。

6

2026.02.02

主流快递单号查询入口 实时物流进度一站式追踪专题
主流快递单号查询入口 实时物流进度一站式追踪专题

本专题聚合极兔快递、京东快递、中通快递、圆通快递、韵达快递等主流物流平台的单号查询与运单追踪内容,重点解决单号查询、手机号查物流、官网入口直达、包裹进度实时追踪等高频问题,帮助用户快速获取最新物流状态,提升查件效率与使用体验。

2

2026.02.02

Golang WebAssembly(WASM)开发入门
Golang WebAssembly(WASM)开发入门

本专题系统讲解 Golang 在 WebAssembly(WASM)开发中的实践方法,涵盖 WASM 基础原理、Go 编译到 WASM 的流程、与 JavaScript 的交互方式、性能与体积优化,以及典型应用场景(如前端计算、跨平台模块)。帮助开发者掌握 Go 在新一代 Web 技术栈中的应用能力。

1

2026.02.02

PHP Swoole 高性能服务开发
PHP Swoole 高性能服务开发

本专题聚焦 PHP Swoole 扩展在高性能服务端开发中的应用,系统讲解协程模型、异步IO、TCP/HTTP/WebSocket服务器、进程与任务管理、常驻内存架构设计。通过实战案例,帮助开发者掌握 使用 PHP 构建高并发、低延迟服务端应用的工程化能力。

1

2026.02.02

Java JNI 与本地代码交互实战
Java JNI 与本地代码交互实战

本专题系统讲解 Java 通过 JNI 调用 C/C++ 本地代码的核心机制,涵盖 JNI 基本原理、数据类型映射、内存管理、异常处理、性能优化策略以及典型应用场景(如高性能计算、底层库封装)。通过实战示例,帮助开发者掌握 Java 与本地代码混合开发的完整流程。

1

2026.02.02

go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

61

2026.01.31

热门下载

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

精品课程

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

共137课时 | 10.8万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

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

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