我們先來看下載函數的兩個形參,function download($file_name,$file_sub_dir)
$filename定義了文件的名稱,$file_sub_dir定義了文件的路徑名,其格式為“/XXX/”,例如"/file/".
接著用一個變量保存下載文件的路徑
$file_path=$_SERVER["DOCUMENT_ROOT"].$file_sub_dir.$file_name;
$_SERVER["DOCUMENT_ROOT"]是服務器的根目錄,從根目錄開始找代表使用的是絕對路徑
然后我們該截取文件的后綴了,如doc、xls、jpg等,這樣做的目的是判斷根據不同類型的文件使用不同的返回方式。
如jpg則使用header("Content-type:image/jpeg"); 二進制文件則使用header("Content-type:Application/octet-stream"); 截取后綴用這句$extension=substr($file_name,strrpos($file_name,".")); strrpos($file_name,".")這個函數的意思是找到后綴前面的小點(.)所在的索引號 substr($file_name,strrpos($file_name,"."))是從索引號開始向后截取
為了讓代碼更加嚴謹,還是應該判斷一下文件是否存在,不存在則返回
if(!file_exists($file_path)){ echo "文件不存在"; return; }
這幾句是下載的通常寫法
//按照字節大小返回 header("Accept-Ranges:bytes"); //返回文件大小 header("Accept-Length:$file_size"); //這里客戶端彈出的對話框,對應的文件名 header("Content-Disposition:attachment;filename=".$file_name);
為了緩解壓力,最好將數據一點一點讀取
$buffer=1024;
$file_count=0;
//這句話用于判斷文件是否結束
while(!feof($fp) && ($file_size-$file_count>0)){
$file_data=fread($fp,$buffer);
//統計讀了多少個字節
$file_count+=$buffer;
echo $file_data; //將數據完整的輸出
}
下面是完整代碼
//下載函數 public function download($file_name,$file_sub_dir){ //對中文文件應該進行轉碼 //$file_name=iconv("utf-8","gb2312",$file_name); $file_path=$_SERVER["DOCUMENT_ROOT"].$file_sub_dir.$file_name; $extension=substr($file_name,strrpos($file_name,".")); if(!file_exists($file_path)){ echo "文件不存在"; return; } $fp=fopen($file_path,"r"); //獲取下載文件的大小 $file_size=filesize($file_path); //返回的文件 if($extension==".jpg"){ header("Content-type:image/jpeg"); }else{ header("Content-type:application/octet-stream"); } //按照字節大小返回 header("Accept-Ranges:bytes"); //返回文件大小 header("Accept-Length:$file_size"); //這里客戶端彈出的對話框,對應的文件名 header("Content-Disposition:attachment;filename=".$file_name); //向客戶端回送數據 $buffer=1024; $file_count=0; //這句話用于判斷文件是否結束 while(!feof($fp) && ($file_size-$file_count>0)){ $file_data=fread($fp,$buffer); //統計讀了多少個字節 $file_count+=$buffer; echo $file_data; //將數據完整的輸出 } //關閉文件 fclose($fp); }