我们先来看下载函数的两个形参,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);
}