受保护下载上的HTTP标头



我用这篇文章来生成和保护我网站上的一些下载链接

我遇到的问题是脚本工作,只是没有巨大的文件。例如,1GB的文件可以完美下载,而7GB的文件则不行。

有人在评论中提到大量下载可能会导致这种情况。

我的头现在看起来是这样的:

header('Content-Description: File Transfer');
header('Content-Type: application/octet-stream');
header('Content-Disposition: attachment; filename="' . basename($fakefilename) . '"');
header('Content-Transfer-Encoding: binary');
header('Expires: 0');
header('Cache-Control: must-revalidate');
header('Pragma: public');
header('Content-Length: ' . filesize($realfilename));
ob_clean();
flush();
readfile($realfilename);
exit;

本指南建议它们应该看起来像这样:

header("Content-Disposition: attachment; filename=" . urlencode($file));    
header("Content-Type: application/force-download");
header("Content-Type: application/octet-stream");
header("Content-Type: application/download");
header("Content-Description: File Transfer");             
header("Content-Length: " . filesize($file));
flush(); // this doesn't really matter.
$fp = fopen($file, "r"); 
while (!feof($fp))
{
    echo fread($fp, 65536); 
    flush(); // this is essential for large downloads
}  
fclose($fp); 

无论如何,我不能让这个工作。有人熟悉HTTP头文件吗,大而不是小的文件不能下载?

任何帮助都是感激的。提前感谢!

这个错误是由filesize调用溢出系统的PHP_MAX_INT引起的,它产生的长度小于整个文件的长度。(在32位机器上大约是2GB)

只有信任内容长度报头而不是文件本身大小的浏览器才会受到影响。

解决方法是改变

header("Content-Length: " . filesize($file));

header("Content-Length: " . exec("stat -c %s ".escapeshellarg($filename)));

最新更新