zoukankan      html  css  js  c++  java
  • 应用phpexcel导出excel文件后打不开的问题解决方法

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

    试了以下方法:

    1.首先区分文件格式是2003,还是2007。 参考原文:https://blog.csdn.net/beyond__devil/article/details/53283352

     if($type == 'excel2003')
    {
    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, 'Excel2007'); $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); 后问题解决。

  • 相关阅读:
    31、[源码]-AOP原理-AnnotationAwareAspectJAutoProxyCreato机
    30、[源码]-AOP原理-注册AnnotationAwareAspectJAutoProxyCreavi
    29、[源码]-AOP原理-AnnotationAwareAspectJAutoProxyCreatovi
    magento 常用的函数
    magento性能优化的教程(非常详细)
    magento性能优化
    magento搜索属性值的设置方法
    Magento 的程序架构与流程
    Magento入门开发教程
    高级Magento模型 EAV
  • 原文地址:https://www.cnblogs.com/imustun/p/9156851.html
Copyright © 2011-2022 走看看