【问题标题】:Create a CSV file with PHP via fopen/fwrite but also write headers to it通过 fopen/fwrite 使用 PHP 创建一个 CSV 文件,但也向其写入标题
【发布时间】:2011-09-28 00:47:48
【问题描述】:

我觉得我在这里很明显,但我还是会发布。

我有一个“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 输出到浏览器)。

【问题讨论】:

  • 如果您运行的是 Apache,您可以使用 .htaccess 文件强制下载:css-tricks.com/snippets/htaccess/…
  • 您也可以使用mod_cern_metamod_headers 通过.htaccess 捎带这些额外的标头

标签: php file-io csv header download


【解决方案1】:

您将无法将标题添加到 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 本身。在我看来,这是解决问题的更好方法。

【讨论】:

  • 显然我没有错误处理,安全性也很低(只是一个 preg_replace),但你应该从中得到想法。
【解决方案2】:

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

如果您的网络服务器没有为 csv 文件设置您想要的标头,您可以说服它这样做。

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

【讨论】:

    猜你喜欢
    • 2015-05-24
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-02-22
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-12-05
    相关资源
    最近更新 更多