php,tp5大文件下载,不会卡死服务器,不会溢出内存,下载200M,300M没啥问题
这篇就不写原理了,直接上代码吧
// 公共下载方法
function downloadFile($filename,$file_dir,$filetype) {
$allowDownExt = array ('jpg','jpeg','gif', 'rar','zip','png','txt','html','mp3','mp4','docx','pptx','.xlsx');
//检测文件是否存在,并且可读
if(!is_file($file_dir) && is_readable($file_dir)) {
return false;
}
//获取文件的扩展名
$fileext=strtolower(pathinfo($file_dir,PATHINFO_EXTENSION));
//检测文件类型是否允许下载
if(!in_array($fileext,$allowDownExt)) {
return false;
}
//设置脚本的最大执行时间,设置为0则无时间限制
set_time_limit(0);
//通过header()发送头信息
//因为不知道文件是什么类型的,告诉浏览器输出的是字节流
header('content-type:application/octet-stream');
//告诉浏览器返回的文件大小类型是字节
header('Accept-Ranges:bytes');
//获得文件大小
$filesize = filesize($file_dir);
//告诉浏览器返回的文件大小
header('Accept-Length:' . $filesize);
//告诉浏览器文件作为附件处理并且设定最终下载完成的文件名称
header("content-disposition: attachment;filename=" . $filename.$filetype);
//针对大文件,规定每次读取文件的字节数为4096字节,直接输出数据
$read_buffer = 1024 * 1024 * 2;
$handle = fopen($file_dir, 'rb');
//总的缓冲的字节数
$sum_buffer = 0;
//只要没到文件尾,就一直读取
while(!feof($handle) && $sum_buffer<$filesize) {
echo fread($handle,$read_buffer);
$sum_buffer+=$read_buffer;
}
//关闭句柄
fclose($handle);
exit;
}