Ed *_*hen 10 php mysql browser prompt download
我有一个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);
Run Code Online (Sandbox Code Playgroud)
$ exportfile是我的代码创建的csv文件.没关系.这样做是:
好的,我已经尝试了很多东西而且没有任何效果.所以,如果有人能帮助我,我会很感激.谢谢.
埃德科恩
Ann*_*nne 34
在PHP文档提供了一个很好的例子:
<?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;
}
?>
Run Code Online (Sandbox Code Playgroud)
编辑 (回复评论,解释)
header('Content-Description: File Transfer');
Run Code Online (Sandbox Code Playgroud)
不要在浏览器中显示,而是传输文件.
header('Content-Type: application/octet-stream');
header('Content-Transfer-Encoding: binary');
Run Code Online (Sandbox Code Playgroud)
文件是二进制文件.
浏览器通常下载二进制文件,除非它们可以显示它们.
header('Content-Disposition: attachment; filename='.basename($file));
Run Code Online (Sandbox Code Playgroud)
使下载对话框显示正确的文件名.
注意:您可以使用任何文件名.
header('Expires: 0');
header('Cache-Control: must-revalidate');
header('Pragma: public');
Run Code Online (Sandbox Code Playgroud)
浏览器不应缓存文件.
在动态内容的情况下,缓存可能会造成麻烦.
header('Content-Length: ' . filesize($file));
Run Code Online (Sandbox Code Playgroud)
将正确的文件大小发送到浏览器,
否则浏览器无法估计传输时间.
ob_clean();
flush();
Run Code Online (Sandbox Code Playgroud)
确保在下载开始之前将标头发送到浏览器.
readfile($file);
Run Code Online (Sandbox Code Playgroud)
将文件发送到浏览器.
exit;
Run Code Online (Sandbox Code Playgroud)
完成:)
| 归档时间: |
|
| 查看次数: |
24262 次 |
| 最近记录: |