繁体   English   中英

PhpSpreadsheet 损坏的 xlsx 文件

[英]PhpSpreadsheet corrupted xlsx file

我在尝试下载 xlsx 文件时遇到问题。 当我在本地测试它时它工作得很好,但是当我将它上传到生产服务器时,文件被损坏了。

这是文件输出: 在此处输入图片说明

这是我使用的代码:

<?php

    require 'conn.php';
    require 'vendor/autoload.php';

    use PhpOffice\PhpSpreadsheet\Spreadsheet;
    use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
    use PhpOffice\PhpSpreadsheet\IOFactory;


    $spreadsheet = new Spreadsheet();
    $sheet = $spreadsheet->getActiveSheet();
    $sheet->setCellValue('A1', '#');
    $sheet->setCellValue('B1', 'First');
    $sheet->setCellValue('C1', 'Last');
    $sheet->setCellValue('D1', 'Handle');

    header('Content-Type: application/vnd.openxmlformats- 
    officedocument.spreadsheetml.sheet');
    header('Content-Disposition: attachment;filename="text.xlsx"');
    header('Cache-Control: max-age=0');
    $writer = IOFactory::createWriter($spreadsheet, 'Xlsx');
    $writer->save('php://output');
    die;

我尝试将标题更改为,但没有帮助:

header('内容类型:应用程序/vnd.ms-excel');

我认为如果在调用 createWriter 静态方法之前添加对输出缓冲区的清理就可以了。

ob_end_clean();
$writer = IOFactory::createWriter($spreadsheet, 'Xlsx');
$writer->save('php://output');

我有同样的症状,这是因为网络服务器在做完之后继续输出东西

$writer->save('php://output');

在我的情况下,在它之后做一个die()是可行的,问题就消失了。 也许它可以为某人节省一点时间。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM