0

在修复与 CSV 相关的下载问题时,我添加了一些 PHP 中常用的标头。之后,添加我执行 CSV 导出测试的那些。从那时起,在我的浏览器中,一个新选项卡将无限打开和关闭。我无法通过还原我所做的更新来阻止它。清除服务器和浏览器 - 缓存和历史记录。尽管如此,在尝试使用旧代码导出时,这些选项卡仍在重新打开。我现在通过sudo pkill -9 chrome在终端上执行来停止浏览器(Chrome)。

我认为新标签的打开和关闭与我添加的强制下载代码有关。

header('Content-Description: File Transfer');
header('Content-Transfer-Encoding: binary');
header('Content-Disposition: attachment; filename='.$filename);
header('Content-Type: application/csv;');
header('Content-Type: application/force-download');
header('Content-Type: application/octet-stream', false);
header('Content-Type: application/download', false);

// file creation 
$file = fopen('php://output', 'w');
$header = array("Group Name","Contact Name","Email","Phone Number","Company Name"); 
fputcsv($file, $header);
foreach ($new_array as $key => $line){ 
    fputcsv($file,$line); 
}
fclose($file); 
exit;

$new_array是从 DB 中获取的数据数组。

我认为问题是因为我忘记添加缓存标头,例如:

header('Cache-Control: public, must-revalidate, max-age=0');
header('Pragma: public');
header('Expires: Sat, 26 Jul 1997 05:00:00 GMT');
header('Last-Modified: '.gmdate('D, d M Y H:i:s').' GMT');

有没有办法阻止这个问题?

查看问题的视频链接

4

1 回答 1

1

@MagnusEriksson 的评论是正确的。

这不是 PHP/JS 甚至浏览器的问题。

我被要求通过在浏览器中打开来测试 CSV 文件以检查问题,并且我尝试了系统提供的“打开方式”选项。这导致了问题,单击导出选项后下载的文件试图在浏览器窗口中打开,这导致再次下载相同的文件并且它像无限循环一样继续。

这不是与代码相关的问题,但我花了一整天的时间。我搜索了很多与 PHP 标头相关的内容。

我还在下面添加了来自@MagnusEriksson 的一些有价值的评论:

  • 没有 PHP 代码可以使浏览器中的选项卡打开和关闭。

  • 你似乎有两个不同的问题。1.没有下载(很可能是PHP)。2. 选项卡不断打开和关闭(这不是PHP 造成的,因为PHP 无法在客户端打开或关闭选项卡)。这看起来像一些 JS/浏览器问题。

于 2020-10-01T10:38:42.270 回答