先上一段代碼,支持大文件下載和斷點續傳,代碼來源互聯網。
set_time_limit(0);// 省略取文件路徑的過程,這里直接是文件完整路徑$filePath = get_save_path() . $File['save_name'];$filePath = realpath($filePath);$outFileExtension = strtolower(substr(strrchr($filePath, "."), 1)); //獲取文件擴展名//根據擴展名 指出輸出瀏覽器格式switch ($outFileExtension) { case "exe" : $ctype = "application/octet-stream"; break; case "zip" : $ctype = "application/zip"; break; case "mp3" : $ctype = "audio/mpeg"; break; case "mpg" : $ctype = "video/mpeg"; break; case "avi" : $ctype = "video/x-msvideo"; break; default : $ctype = "application/force-download";}header("Cache-Control:");header("Cache-Control: public");//設置輸出瀏覽器格式header("Content-Type: $ctype");header("Content-Disposition: attachment; filename=" . basename($filePath));header("Accept-Ranges: bytes");$size = filesize($filePath);//如果有$_SERVER['HTTP_RANGE']參數if (isset ($_SERVER['HTTP_RANGE'])) { /*Range頭域 Range頭域可以請求實體的一個或者多個子范圍。 例如, 表示頭500個字節:bytes=0-499 表示第二個500字節:bytes=500-999 表示最后500個字節:bytes=-500 表示500字節以后的范圍:bytes=500- 第一個和最后一個字節:bytes=0-0,-1 同時指定幾個范圍:bytes=500-600,601-999 但是服務器可以忽略此請求頭,如果無條件GET包含Range請求頭,響應會以狀態碼206(PartialContent)返回而不是以200 (OK)。 */ // 斷點后再次連接 $_SERVER['HTTP_RANGE'] 的值 bytes=4390912- list ($a, $range) = explode("=", $_SERVER['HTTP_RANGE']); //if yes, download missing part str_replace($range, "-", $range); //這句干什么的呢。。。。 $size2 = $size - 1; //文件總字節數 $new_length = $size2 - $range; //獲取下次下載的長度 header("HTTP/1.1 206 Partial Content"); header("Content-Length: $new_length"); //輸入總長 header("Content-Range: bytes $range$size2/$size"); //Content-Range: bytes 4908618-4988927/4988928 95%的時候} else { //第一次連接 $size2 = $size - 1; header("Content-Range: bytes 0-$size2/$size"); //Content-Range: bytes 0-4988927/4988928 header("Content-Length: " . $size); //輸出總長}//打開文件$fp = fopen("$filePath", "rb");//設置指針位置if (!empty($range)) { fseek($fp, $range);}//虛幻輸出while (!feof($fp)) { print (fread($fp, 1024 * 8)); //輸出文件 flush(); //輸出緩沖 ob_flush();}fclose($fp);exit ();
代碼有詳細的解釋,也很清楚,但是在實際使用時還是小文件可以下載,大文件只能下載前半部分或者出現文件已損壞的情況。查看nginx日志發現如下報錯
2018/08/01 07:43:20 [crit] 13906#0: *1479 open() "/usr/local/nginx/fastcgi_temp/0/02/0000000020" failed (13: Permission denied) while reading upstream,
原來在下載大文件時,文件大小超過配置的proxy_temp_file_write_size值時,nginx會將文件寫入到臨時目錄下,如果該目錄沒有權限,就寫不了,那下載只能下載緩從區的內容了。
核實/usr/local/nginx/fastcgi_temp/目錄的權限分組,并不在nginx運行賬號組下,即然知道了問題原因,那就好辦了。給予寫權限,或者將目錄改為nginx運行賬號組下就OK了
cd /usr/local/nginx/ chmod -R 766 fastcgi_temp/或者chown -R nginx:nginx fastcgi_temp/ #nginx根據各自情況可能是不能的賬戶
總結
以上所述是小編給大家介紹的nginx+php-fpm實現大文件下載排坑的過程,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VEVB武林網網站的支持!
新聞熱點
疑難解答