说明
- 实测下载后的文件与源文件哈希值一致,保证数据传输安全一致。
- 如果下载到的文件每次都165KB左右,和源文件大小不符合,需要用IDE打开下载的文件,看看是否报致命错误,提示超过最大内存限制。这个与php.ini中的“memory_limit”参数配置有关,所以方法的$kilobyte参数不要设置过大。
- 如果实际下载速率低于代码中配置的速率,需要考虑是云服务器带宽或者其中某个网络链路的问题。
- 由于添加了下载响应头的缘故,所以遇到任何文件都会强制下载。
代码
/**
* @function 自定义文件下载速度
* @param $file_path string 文件路径
* @param $kilobyte int 每秒发送多少千字节数据(有波动)
* @param $file_name string 文件名,无需后缀,自定义下载的初始文件名
* @return void
* @other 并未判断文件是否存在的逻辑,所以请前置逻辑判断。
*/
function speedLimitedDownload($file_path, $kilobyte = 1024, $file_name = '') {
$file_info = pathinfo($file_path);
header('Content-Disposition:attachment; filename="'. ($file_name ? $file_name . '.' . $file_info['extension'] : $file_info['basename']) . '"');
header('Content-Type:"' . mime_content_type($file_path) . '"');
header('Content-Length:' . filesize($file_path));
//使用二进制和只读方式打开文件资源
$handle = fopen($file_path, 'rb');
//判断文件指针是否到了文件末尾
while (! feof($handle)) {
// 输出数据到客户端
echo fread($handle, $kilobyte * 1024);
//刷新缓冲区,使其直接输出到客户端
flush();
//此处意思是设置每秒输出多少个字节的数据。
sleep(1);
}
fclose($handle);
}