thinkphp6.0 html生成pdf

安装wkhtmltopdf

命令行安装

1.更新软件包列表

sudo apt update

2.‌安装 wkhtmltopdf

sudo apt install wkhtmltopdf

3.‌安装必要的依赖项(如需支持图形界面功能)

sudo apt install xvfb

4.测试安装是否成功

wkhtmltopdf --version

5.安装中文包

sudo apt update

sudo apt install fonts-wqy-zenhei fonts-noto-cjk

6.验证字体是否安装成功

fc-list :lang=zh

7.html中加上字体

body {

font-family: "WenQuanYi Zen Hei", "SimSun", "Noto Sans CJK", sans-serif;

}

php代码

复制代码
    public function generatePdf(Request $request){
        $param = $request->param();
        header('Access-Control-Allow-Origin: *'); // 允许所有来源跨域
        header('Access-Control-Allow-Methods: GET, POST'); // 允许的HTTP方法
        header('Access-Control-Allow-Headers: Content-Type'); // 允许的请求头

        $feneralPDF = new GeneralPDF($param['requestid']);
        $htmlContent = $feneralPDF->templateHtml();


        // 配置wkhtmltopdf路径
//        $wkhtmltopdfPath = '/usr/local/bin/wkhtmltopdf';
//        if (!file_exists($wkhtmltopdfPath)) {
            $wkhtmltopdfPath = '/usr/bin/wkhtmltopdf'; // Ubuntu默认安装路径
//        }

        // 创建临时文件
        $tempHtmlFile = tempnam(sys_get_temp_dir(), 'pdf_') . '.html';
        $tempPdfFile = tempnam(sys_get_temp_dir(), 'pdf_') . '.pdf';

        // 写入HTML内容到临时文件
        file_put_contents($tempHtmlFile, $htmlContent);

        // 构建命令
        $command = sprintf(
            '%s --encoding utf-8 --margin-top 10mm --margin-bottom 10mm --margin-left 10mm --margin-right 10mm %s %s 2>&1',
            $wkhtmltopdfPath,
            escapeshellarg($tempHtmlFile),
            escapeshellarg($tempPdfFile)
        );

        // 执行命令
        $output = [];
        $returnVar = 0;
        exec($command, $output, $returnVar);

        // 检查执行结果
        if ($returnVar !== 0 || !file_exists($tempPdfFile)) {
            throw new \Exception('PDF生成失败: ' . implode("\n", $output));
        }

        // 读取PDF内容
        $pdfContent = file_get_contents($tempPdfFile);

        // 清理临时文件
        unlink($tempHtmlFile);
        unlink($tempPdfFile);
        $filename = $feneralPDF->flowname.'.pdf';
        // 设置响应头
        header('Content-Type: application/pdf');
        header("Content-Disposition: inline; filename={$filename}");
        header('Content-Length: ' . strlen($pdfContent));
        echo $pdfContent;
        ob_flush();
        flush();
    }
相关推荐
打小就很皮...9 小时前
html2canvas + jsPDF 生成 PDF 的踩坑与解决方案总结
前端·pdf
北风toto9 小时前
Spring Boot / Spring Cloud 配置文件加密详解:使用 jasypt-spring-boot 实现 ENC() 加密
spring boot·后端·spring cloud
代码羊羊9 小时前
Rust 格式化输出完全攻略:从入门到精通
开发语言·后端·rust
Rust研习社9 小时前
Rust + PostgreSQL 极简技术栈应用开发
开发语言·数据库·后端·http·postgresql·rust
geovindu10 小时前
go:Template Method Pattern
开发语言·后端·设计模式·golang·模板方法模式
白晨并不是很能熬夜10 小时前
【RPC】第 4 篇:服务发现 — Zookeeper + 缓存容错
java·后端·程序人生·缓存·zookeeper·rpc·服务发现
优化控制仿真模型10 小时前
27考研数学一、二、三历年真题及答案解析PDF电子版(1987-2026年)
经验分享·pdf
huluang10 小时前
解决 Adobe Acrobat 裁剪 PDF 后内容仍存留的问题
pdf
我这一拳20年的功力10 小时前
深入解析 XXL-JOB 核心原理:从 Quartz 到自研时间轮
后端
其实秋天的枫10 小时前
27考研数学一、二、三历年真题及答案解析PDF电子版(1987-2026年)
经验分享·pdf