說明 實測下載後的文件與源文件哈希值一致,保證數據傳輸安全一致。 如果下載到的文件每次都165KB左右,和源文件大小不符合,需要用IDE打開下載的文件,看看是否報致命錯誤,提示超過最大記憶體限制。這個與php.ini中的“memory_limit”參數配置有關,所以方法的$kilobyte參數不要設置 ...
說明
- 實測下載後的文件與源文件哈希值一致,保證數據傳輸安全一致。
- 如果下載到的文件每次都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);
}