PHP在本机可以正常导出Excel,在上Linux就提示ERR_EMPTY_RESPONSE,下面说一下怎么不降版本还能正常导出Excel,解决上面的问题。
使用导出Excel的时候显示错误页面提示如下,这时候发现上传Excel都可以正常读取数据,只是导出的时候不可以。
data:image/s3,"s3://crabby-images/6ac1b/6ac1becc70521cc2626392acd46771787a8a3147" alt=""
我这里使用的PHP版本是7.1。PHPExcel版本用的是1.8.1。github地址:
https://github.com/PHPOffice/PHPExcel/tree/1.8.1。可以看到作者已经3年没更新过了。
data:image/s3,"s3://crabby-images/8f70b/8f70b64180886f5868c674c06253e4b955d2ffd4" alt=""
将PHPExcel里面的Class内容都拷贝到thinkphp的vendor目录下。重命名为PHPExcel。也就是将之前老的插件换成这个1.8.1的版本。
data:image/s3,"s3://crabby-images/726a0/726a0b51fb7199c26030b061133ca3d1d9a5dc0e" alt=""
具体怎么写Excel和引入插件我就不说了。说下代码方面的写法。
问题其实集中出现在Excel输出这里。(下面是成功导出Excel的写法,前面生成Excel的部分略去了)定义头部后直接输出。
$filename = "模板文件".date("YmdHis").rand(1000,9999);$filename = iconv("utf-8", "gb2312", $filename);header("Pragma: public");header("Expires: 0");header("Cache-Control:must-revalidate, post-check=0, pre-check=0");header("Content-Type:application/force-download");header("Content-Type:application/vnd.ms-execl");header("Content-Type:application/octet-stream");header("Content-Type:application/download");;header('Content-Disposition:attachment;filename='.$filename.'.xls');header("Content-Transfer-Encoding:binary");$objWriter- save('php://output');
data:image/s3,"s3://crabby-images/30668/306684a287efd16e41596b1ac0855c07a447313a" alt=""
data:image/s3,"s3://crabby-images/e9bf8/e9bf8e58276d731f6e6e6832c9c59f59668d8875" alt=""
也可以使用PhpSpreadsheet来读写Excel。
github:https://github.com/PHPOffice/PhpSpreadsheet
文档:https://phpspreadsheet.readthedocs.io/en/develop/
data:image/s3,"s3://crabby-images/cee83/cee83b9c8fcfd5d3f19b144f95f64460a3ba609b" alt=""
data:image/s3,"s3://crabby-images/9b7d1/9b7d1d63b9c290e17034264c19ad6b7ecf5e4690" alt=""
以上就是关于PHP7导出Excel报ERR_EMPTY_RESPONSE的相关解决步骤和方法,感谢大家的阅读和对ZaLou.Cn的支持。