1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > php用excel打不开 应用phpexcel导出excel文件后打不开的问题

php用excel打不开 应用phpexcel导出excel文件后打不开的问题

时间:2020-01-01 16:29:43

相关推荐

php用excel打不开 应用phpexcel导出excel文件后打不开的问题

应用phpexcel导出excel文件后打不开,提示“文件格式或文件扩展名无效,请确定文件未损坏,并且文件扩展名与文件的格式匹配”。

试了以下方法:

1.首先区分文件格式是,还是。 参考原文:/beyond__devil/article/details/53283352

if($type == 'excel')

{header('Content-Type: application/vnd.ms-excel');header("Content-Disposition: attachment;filename='{$fileName}'");header('Cache-Control: max-age=0');$objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');$objWriter->save('php://output');

}else{header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');header("Content-Disposition: attachment;filename='{$fileName}'");header('Cache-Control: max-age=0');$objWriter = \PHPExcel_IOFactory:: createWriter($objPHPExcel, 'Excel');$objWriter->save( 'php://output');

}

原因:1.发送header()头之前,不知道又啥特殊字符输出(可能是BOM,也可能是其他),导致php报错!然后将报错内容输出到了Excel

2.极大可能是:文件BOM头问题,生成的Excel文件头部添加了BOM头!

解决方案:

1.在输出Excel前,缓冲区中处理BOM头(可能是其他字符)ob_end_clean();

ob_start();

在header()函数调用之前,清楚之前的错误输出!

2.有人第一步过后,问题未解决。通过ob_get_contents()查看导出内容,并未发现BOM头。

再就是应用了框架,返回的静态页输出成了excel文件。

试了以上方法后,还是没有问题,最后查看导出的文件内容,意识到是跳转到静态页导致的。

加上exit($contents);后问题解决。

转载声明:本站文章除注明转载外,均为本站原创或编译。欢迎任何形式的转载,但请务必注明出处,尊重他人劳动。

欢迎捐赠赞赏

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。