我觉得我在这里显得很遗憾,但无论如何我都会发帖。
我有一个'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输出到浏览器)。
答案 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服务器。