我們先來看下載函數的兩個形參,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);
}






