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

9260问题描述:

导出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框架】

$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 "";

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

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

笔记,以备忘。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值