我有一个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文件.没关系.这样做是:
> $fullpath以非常奇怪的格式显示在浏览器下载提示中:download_emailclientaddresses.csv
>下载时,下载当前网页或csv文件和当前网页的组合.
好的,我尝试了很多东西,没有任何效果.所以,如果有人能帮助我,我会很感激.谢谢.
埃德科恩
解决方法:
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;
完成:)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。