解决PHPExcel在IE8无法下载的问题 - Go语言中文社区

解决PHPExcel在IE8无法下载的问题


问题描述:

导出Excel,用的是PHPExcel的类库。导出excel文件在IE8浏览器下载提示出错,提示“无法下载 / (来自 x.x.x.x)。无法打开Internet站点。请求的站点不可用或无法找到。请稍后重试。”,chrome和firefox中正常


部分代码

$objPHPExcel->setActiveSheetIndex(0);
ob_end_clean();//清除缓冲区,避免乱码
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename="xxx记录.xls"');
header('Cache-Control: max-age=0');
$objWriter = IOFactory::createWriter($objPHPExcel, 'Excel5');
$objWriter->save('php://output');


网上查找方案:

//设置输入到浏览器
header('Pragma:public');
header('Content-Type:application/x-msexecl;name="xxx.xls"');
header("Content-Disposition:inline;filename="xxx.xls"");
$objWriter->save('php://output');
注意header不用多写,有这三个就够了,实用inline和x-msescel及name巧妙避过IE的规则。

-------------------------------------------------------

经测试以上方案,问题依然存在。

-------------------------------------------------------



继续测试,以下搭配可以弹窗提示打开或者下载,但是点击下载还是提示无法下载。

header('Pragma:public');
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition:inline;filename="xxx记录.xls"');
$objWriter->save('php://output');
-------------------------------------------------------



最后解决方案:

思路:将excel直接生成文件,给浏览器跳转下载。(用header实现的跳转不能解决问题)

以下是解决的主要代码【CI框架】

<span style="font-family:Microsoft YaHei;">$objPHPExcel->setActiveSheetIndex(0);
ob_end_clean();//清除缓冲区,避免乱码
$filename = 'xxx记录.xls';//文件名(带后缀)
$objWriter = IOFactory::createWriter($objPHPExcel, 'Excel5');
if (preg_match('/MSIE/',$_SERVER['HTTP_USER_AGENT'])) {
    $path = EXCEL_FILES_PATH.date("Y/m/d/");
    if(!file_exists($path)){
        mkdir($path,DIR_WRITE_MODE,true);
        //删除旧文件
        $this->load->helper('file');
        $old_floder = EXCEL_FILES_PATH.date("Y/m/d/", strtotime("-1days"));
        delete_files($old_floder, TRUE);    //删除所有在path下的文件夹与文件
        log_message('debug', __FUNCTION__. ', L'.__LINE__.', delete_files $old_floder:'.$old_floder);
    }
    $filename = $path.$filename;
    $objWriter->save($filename);//生成excel文档以提供下载
    unset($objWriter);
    $this->load->helper('url');
    log_message('debug', __FUNCTION__. ', L'.__LINE__.', created $filename:'.$filename);
    echo "<script language="javascript">window.location='".base_url().$filename."';</script>";
    exit;
}
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename="'.$filename.'"');
header('Cache-Control: max-age=0');
$objWriter = IOFactory::createWriter($objPHPExcel, 'Excel5');
$objWriter->save('php://output');
#end</span>

此方法只能算解决当前的excel导出问题。生成的文件,可能导致服务器存储空间不足等相关问题,需注意。

笔记,以备忘。



版权声明:本文来源CSDN,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/isealand/article/details/47025181
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。
  • 发表于 2019-09-13 14:51:00
  • 阅读 ( 2024 )
  • 分类:

0 条评论

请先 登录 后评论

官方社群

GO教程

猜你喜欢