无法使用PHP在Safari上下载我的CSV文件

时间:2016-07-29 12:47:12

标签: php csv safari

我在safari上导出我的csv文件时遇到了一个奇怪的问题,它只是在浏览器上显示而不是下载。虽然相同的代码正在使用Firefox和Crome.I已搜索但没有任何对我有用。请帮忙。这是我的代码 -

<?php
ob_clean();
ob_start();
header('Content-Type: text/csv');
header('Content-Disposition: attachment; filename="export.csv"');
header('Pragma: no-cache');    
header('Expires: 0');

function exportData() {

$fp = fopen('php://output', 'w');
fputcsv($fp, array('Market ID', 'Market Name', 'Suburb', 'State', 'Start Time', 'End Time', 'Status',"~"));
include "database.php";


$dbquery = @$_POST['query'];
$queryAllUser = $dbquery;       


$resultAllUser = mysql_query($queryAllUser);
$countAllUser = mysql_num_rows($resultAllUser);


if($countAllUser > 0)
{
while($rowMarketId= mysql_fetch_assoc($resultAllUser))
{  

   $marketId =     $rowMarketId['mrkt_id'];
   $isCancel =     $rowMarketId['is_cancel'];
   $openning_tim = $rowMarketId['openning_time'];
   $closing_tim =  $rowMarketId['closing_time'];
   $suburb =  $rowMarketId['suburb']; 
   $name =  $rowMarketId['name'];
   $state =  $rowMarketId['state'];       
   if($isCancel == 0)
   {
            $status_type = "Open";
   }
    else
    {
            $status_type = "Close";
    }

      $val = array();
      $val[] = $marketId;
      $val[] = $name;
      $val[] = $suburb;
      $val[] = $state;
      $val[] = $openning_tim;
      $val[] = $closing_tim;
      $val[] = $status_type;
      $val[] = "~";

     fputcsv($fp, $val);

  }


  }


  }

   exportData();

  ?>

1 个答案:

答案 0 :(得分:0)

header('Content-Description: File Transfer');
header('Content-Type: application/octet-stream');
header("Content-Type: application/force-download");
header('Content-Disposition: attachment; filename=' .urlencode(basename($filename)));
header('Expires: 0');
header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
header('Pragma: public');
header('Content-Length: ' . filesize($filename));

尝试使用此标题........这应该有用..