通常,当我想允许用户下载文件而不泄露确切位置时,我只是使用这样的东西让他们下载文件:
header("Pragma: public");
header("Expires: 0");
header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
header("Content-Type: application/octet-stream");
header("Content-Disposition: attachment; filename=\"" . $filename) . "\";");
header("Content-Transfer-Encoding: binary");
header("Content-Length: " . filesize($filename));
readfile("$filename");
但是如果他们使用的是现代浏览器或其他下载客户端,并且他们暂停下载并尝试恢复它,则脚本(假设它们仍然经过身份验证或其他)将从头开始重新发送标头和文件内容,从而打破了下载,基本上要求从头开始重新加载文件。
如何启用我的脚本以补偿已暂停(以及相应的已恢复)的下载?
答案 0 :(得分:10)
使用php的内置fopen打开文件,然后fseek到正确的位置(基于请求标头中的范围),然后使用fpassthru而不是使用readfile返回部分文件。
您可以在fread
的评论中找到php中的一些示例代码答案 1 :(得分:5)
您需要读取Range,If-Range等请求标头,然后搜索文件中的正确位置。通常,Web服务器会在普通文件上为您执行此操作。这有点复杂,但这可能会让你开始:
http://forums.asp.net/t/1218116.aspx
http://www.notes411.com/dominosource/tips.nsf/0/480C4E3BE825F69D802571BC007D5AC9!opendocument
对于第二个链接,代码在第12部分