php:无法获得带有readfile的excel的下载提示

时间:2012-10-15 09:12:50

标签: php excel header fopen readfile

我在这里搜索了整个网站以及其他许多网站但却找不到解决这个众所周知问题的方法。我无法通过php的readfile下载excel文件。我也尝试过fopen,print(fread),fclose组合,但这也不起作用。 请求网址是https我在http:

时收到提示
 $path=$_SERVER['DOCUMENT_ROOT'].'/uploads/'.$legit;  
 header('Content-Description: File Transfer');  
 header('Content-Transfer-Encoding: binary');
 header('Accept-Ranges: bytes'); 
 header("Content-Disposition: attachment; filename='file.xls'");                                                       
 header('Content-Type: application/vnd.ms-excel');
 header('Content-Length: ' . filesize(\$path));
 header('Cache-Control: must-revalidate');
 header('Pragma: public');
 header('Expires: 0');
 ob_clean();
 readfile($path);
 exit;
  /*   IF ($file = FOPEN($path, 'rb')) {
   WHILE(!FEOF($file) and (CONNECTION_STATUS()==0)) {
     PRINT(FREAD($file, 1024*8));
 FLUSH();
     }
   FCLOSE($file);
    }
  RETURN((CONNECTION_STATUS()==0) and !CONNECTION_ABORTED());
   exit;
       }    */

请求,响应标题都在firebug中显示正常,但没有提示。

我的客户端标头随dojo / request API一起发送:

  var args={
             headers :{
                        'Content-Type' :'application/x-www-form-urlencoded',
                        'Accept' :'application/vnd.ms-excel',
                        'X-Requested-With':'XMLHttpRequest'
                            },
                            method:'GET',
                            timeout:10000
                        }
   var deferred=request.get(url,args);//the url is https it worked with http

有任何帮助可以解决这个问题吗?

1 个答案:

答案 0 :(得分:0)

如果您使用AJAX请求请求数据,则响应将在后台透明地返回到AJAX进程。您必须将当前页面的主URL重定向到文件下载URL才能激发文件下载过程。