我有一个php / mysql网站,我正在尝试下载逗号分隔文件(CSV)。我创建的csv文件包含逗号分隔的数据(名称,地址,城市,州)。我创建了csv文件,并将其放在站点的/ downloads目录中。到现在为止还挺好。我一直在寻找线和触发浏览器下载提示的代码,我最常见的是:
$path = $_SERVER['DOCUMENT_ROOT'];
$exportfile = "emailclientaddresses.csv";
$fullpath = "downloads/" . $exportfile;
header("Content-type: text/plain");
header("Content-Length: ".filesize($exportfile));
header("Content-Disposition: attachment; filename=" . $fullpath);
$ exportfile是我的代码创建的csv文件。没关系。这样做是:
好的,我尝试了很多东西而且没有任何效果。所以,如果有人能帮助我,我会很感激。谢谢。
科恩·科恩答案 0 :(得分:33)
PHP documentation提供了一个很好的例子:
<?php
$file = 'monkey.gif';
if (file_exists($file)) {
header('Content-Description: File Transfer');
header('Content-Type: application/octet-stream');
header('Content-Disposition: attachment; filename='.basename($file));
header('Content-Transfer-Encoding: binary');
header('Expires: 0');
header('Cache-Control: must-revalidate');
header('Pragma: public');
header('Content-Length: ' . filesize($file));
ob_clean();
flush();
readfile($file);
exit;
}
?>
编辑 (对评论,解释的回应)
header('Content-Description: File Transfer');
不要在浏览器中显示,而是传输文件。
header('Content-Type: application/octet-stream');
header('Content-Transfer-Encoding: binary');
文件是二进制文件 浏览器通常下载二进制文件,除非它们可以显示它们。
header('Content-Disposition: attachment; filename='.basename($file));
使下载对话框显示正确的文件名 注意:您可以使用任何文件名。
header('Expires: 0');
header('Cache-Control: must-revalidate');
header('Pragma: public');
浏览器不应缓存文件 在动态内容的情况下,缓存可能会造成麻烦。
header('Content-Length: ' . filesize($file));
将正确的文件大小发送到浏览器,
否则浏览器无法估计传输时间。
ob_clean();
flush();
确保在下载开始之前将标题发送到浏览器。
readfile($file);
将文件发送到浏览器。
exit;
完成:)