[英]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.