php下载excel无法打开的解决方法


Posted in PHP onDecember 24, 2013

php下载excel文件,
1、在下载的过程中不要 输出任何非文件信息,比如 echo log信息。 否则下载后的文件无法打开,提示格式错误或者文件被破坏。
2、 输出的excel格式一定要和后缀名保存一直,否也会提示格式错误或者文件被破坏

if (file_exists(CACHE_PATH . $file_name)){
            //$this->logger->error('file realpath:'.realpath(CACHE_PATH . $file_name));
      header( 'Pragma: public' );
      header( 'Expires: 0' );
      header( 'Content-Encoding: none' );
      header( 'Cache-Control: must-revalidate, post-check=0, pre-check=0' );
      header( 'Cache-Control: public' );
   header( 'Content-Type: application/vnd.ms-excel');  
      header( 'Content-Description: File Transfer' );
      header( 'Content-Disposition: attachment; filename=' . $file_name );
      header( 'Content-Transfer-Encoding: binary' );
      header( 'Content-Length: ' . filesize ( CACHE_PATH . $file_name ) );
      readfile ( CACHE_PATH . $file_name );
  } else {
   $this->logger->error('export model :'.$id.' 错误:未生产文件');
      echo '<script>alert(\'export error, file not exists!\')</script>';
  }
PHP 相关文章推荐
比较全的PHP 会话(session 时间设定)使用入门代码
Jun 05 PHP
php中检查文件或目录是否存在的代码小结
Oct 22 PHP
php数组合并array_merge()函数使用注意事项
Jun 19 PHP
PHP实现将HTML5中Canvas图像保存到服务器的方法
Nov 28 PHP
php实现检查文章是否被百度收录
Jan 27 PHP
在Mac OS上搭建PHP的Yii框架及相关测试环境
Feb 14 PHP
简单的pgsql pdo php操作类实现代码
Aug 25 PHP
详解PHP用substr函数截取字符串中的某部分
Dec 03 PHP
TP(thinkPHP)框架多层控制器和多级控制器的使用示例
Jun 13 PHP
php图片裁剪函数
Oct 31 PHP
php根据命令行参数生成配置文件详解
Mar 15 PHP
PHP+fiddler抓包采集微信文章阅读数点赞数的思路详解
Dec 20 PHP
php calender(日历)二个版本代码示例(解决2038问题)
Dec 24 #PHP
discuz免激活同步登入代码修改方法(discuz同步登录)
Dec 24 #PHP
phpexcel导入excel数据使用方法实例
Dec 24 #PHP
php生成excel列序号代码实例
Dec 24 #PHP
php jquery 多文件上传简单实例
Dec 23 #PHP
php安装xdebug/php安装pear/phpunit详解步骤(图)
Dec 22 #PHP
PHP变量的定义、可变变量、变量引用、销毁方法
Dec 20 #PHP
You might like
将数字格式的计算结果转为汉字格式
2006/10/09 PHP
php imagecreatetruecolor 创建高清和透明图片代码小结
2010/05/15 PHP
php 学习资料零碎东西
2010/12/04 PHP
Javascript 面向对象 对象(Object)
2010/05/13 Javascript
关于event.cancelBubble和event.stopPropagation()的区别介绍
2011/12/11 Javascript
javascript面向对象编程代码
2011/12/19 Javascript
JavaScript 动态加载脚本和样式的方法
2015/04/13 Javascript
基于jQuery实现交互体验社会化分享代码附源码下载
2016/01/04 Javascript
浅谈window.onbeforeunload() 事件调用ajax
2016/06/29 Javascript
在web中js实现类似excel的表格控件
2016/09/01 Javascript
JavaScript学习笔记整理_简单实现枚举类型,扑克牌应用
2016/09/19 Javascript
在ABP框架中使用BootstrapTable组件的方法
2017/07/31 Javascript
js防刷新的倒计时代码 js倒计时代码
2017/09/06 Javascript
jquery实现左右轮播图效果
2017/09/28 jQuery
Vue数据监听方法watch的使用
2018/03/28 Javascript
使用webpack-dev-server处理跨域请求的方法
2018/04/18 Javascript
vue-router3.0版本中 router.push 不能刷新页面的问题
2018/05/10 Javascript
解决Vue-cli npm run build生产环境打包,本地不能打开的问题
2018/09/20 Javascript
微信小程序地图(map)组件点击(tap)获取经纬度的方法
2019/01/10 Javascript
完美解决通过IP地址访问VUE项目的问题
2020/07/18 Javascript
教你如何将 Sublime 3 打造成 Python/Django IDE开发利器
2014/07/04 Python
让 python 命令行也可以自动补全
2014/11/30 Python
Python遍历目录的4种方法实例介绍
2015/04/13 Python
Pycharm学习教程(1) 定制外观
2017/05/02 Python
Python3 加密(hashlib和hmac)模块的实现
2017/11/23 Python
Python中property函数用法实例分析
2018/06/04 Python
Canvas实现保存图片到本地的示例代码
2018/06/28 HTML / CSS
德国家具在线:Fashion For Home
2017/03/11 全球购物
美国男士内衣品牌:Tommy John
2017/12/22 全球购物
视光学毕业生自荐书范文
2014/02/13 职场文书
幼儿园父亲节活动方案
2014/03/11 职场文书
户外活动策划方案
2014/03/12 职场文书
农村党员一句话承诺
2014/05/30 职场文书
综合素质评价个性与发展自我评价
2015/03/06 职场文书
退税申请报告怎么写
2015/05/18 职场文书
Python实现socket库网络通信套接字
2021/06/04 Python