使用PHP通过fopen / fwrite创建一个CSV文件,但也要为其写入标题

时间:2011-09-28 00:47:48

标签: php file-io csv header download

我觉得我在这里显得很遗憾,但无论如何我都会发帖。

我有一个'csv.php',它创建了一个csv文件,简单的例子:

// csv.php
$fh = fopen('report.csv', 'w') or die("can't open file");
while ($row = mysql_fetch_row($result)) { 
    fputcsv($fh, $row);
}
fclose($fh);

在单独的页面上,有一个简单的锚元素链接到上面的文件。所以在home.html上有:

<a href='report.csv'>Report</a>

一个用户将运行csv.php,另一个用户将转到home.html并稍后点击该链接。这工作正常,创建CSV,数据在那里,锚链接通过。

我知道如果我echo输出CSV,我会添加各种标题,例如:

header("Content-type: application/csv");
header("Content-Disposition: attachment; filename=file.csv");
header("Pragma: no-cache");
header("Expires: 0");

但是如何将这些标头添加到文件report.csv?我认为这是必需的,因为firefox拒绝将csv视为可下载文件(当单击锚点时,它只是将csv输出到浏览器)。

2 个答案:

答案 0 :(得分:5)

您将无法将标头添加到report.csv本身。您也可以使用代理脚本,例如download.php?report=report.csv

然后,您将执行以下操作:

$csv = file_get_contents("./csv_directory/" . preg_replace("#/#", "", $_GET['report']);
header("Content-type: application/csv");
header("Content-Disposition: attachment; filename=file.csv");
header("Pragma: no-cache");
header("Expires: 0");
echo $csv;

大笔记
正如@Pat所提到的那样(当我在寻找合适的语法时),如果您正在使用apache并具有访问权限,则可以使用.htaccess或修改httpd.conf本身。在我看来,这是解决问题的更好方法。

答案 1 :(得分:2)

标头不是文件的一部分,它们是HTTP响应的一部分。

如果您的网络服务器没有为csv文件设置所需的标题,您可能会说服它这样做。

或者,如果您不能(或不想),请参阅sberry2A的答案,通过php提供文件,并以此方式控制Web服务器。