解决PHPExcel在IE8无法下载的问题
来源:互联网 发布:智能数据的定义 编辑:程序博客网 时间:2024/06/05 15:14
问题描述:
导出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导出问题。生成的文件,可能导致服务器存储空间不足等相关问题,需注意。
笔记,以备忘。
0 0
- 解决PHPExcel在IE8无法下载的问题
- 在IE8下解决无法调用迅雷下载的问题
- 在IE8下解决无法调用迅雷下载的问题
- 在IE8下解决无法调用迅雷下载的问题
- PHPExcel部署在IIS服务器无法下载问题的处理
- 解决getElementsByClassName在IE8之前无法使用的问题
- 解决IE8下圆角无法显示的问题
- 解决IE8开发工具最小化在任务栏无法使用问题
- 解决eWebEditor编辑器在IE7跟IE8中无法正常使用的问题
- 解决IE8,IE9 在onmouseover下闪烁,无法正常滚动的问题
- 解决安装IE8后,VS2005无法调试的问题
- 解决IE8无法显示PNG文件的问题(注册表)
- ECCMS解决IE8无法上传图片的问题
- window.open()在IE8下报错,输出文件无法下载,以及打开多个窗口重复的问题
- Gmail在IE8下无法显示图片的问题
- 解决IE8无法显示本地图片问题
- 华表Cell的网页插件在IE8中无法显示的问题 | #华表Cell #报表 #IE8
- thinkphp使用view的时候无法利用phpexcel导出数据问题的解决
- 几个强大的linux命令和命令解析函数getopt()
- java枚举类型enum的使用
- 对称加密和分组加密中的四种模式(ECB、CBC、CFB、OFB)
- flume的几个经典配置案例
- 为什么基类的析构函数是虚函数?
- 解决PHPExcel在IE8无法下载的问题
- 弧形进度条(动画版)
- 第五章—语句
- Online Judge System For SzNOI 题库 语法百题 C++ d019
- 响应消息的内容类型 text/html; charset=utf-8与绑定(text/xml; charset=utf-8)的内容类型不匹配
- 详解C++中的引用
- 【mysql】数据库经典快速小操作
- ZigZag Conversion(java)
- poll