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

Chr*_*ris 3 php csv file-io 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);
Run Code Online (Sandbox Code Playgroud)

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

<a href='report.csv'>Report</a>
Run Code Online (Sandbox Code Playgroud)

一个用户将运行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");
Run Code Online (Sandbox Code Playgroud)

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

sbe*_*rry 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;
Run Code Online (Sandbox Code Playgroud)

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