PHP的文件下载方法(并解决IOS自带浏览器下载乱码后缀显示HTML的问题)
/*
封装函数:
参数说明----$file_name:文件名
$file_sub_dir:文件下载的子路径
*/
function file_dowm($file_name,$file_sub_dir){
//文件转码
// $file_name=iconv("utf-8","gb2312",$file_name);
//使用绝对路径
$file_path=$_SERVER['DOCUMENT_ROOT']."$file_sub_dir";
//打开文件---先判断再操作
if(!file_exists($file_path)){
echo "文件不存在";
return ; //直接退出
}
ob_end_clean();
//存在--打开文件
$fp=fopen($file_path,"r");
//获取文件大小
$file_size=filesize($file_path);
// //这里可以设置超过多大不能下载
// if($file_size>5000) {
// echo "文件太大不能下载";
// return;
// }
// header('Content-type:application/pdf');//下载的文件类型信息(指定文件类型下载)
// http 下载需要的响应头
// header("Content-type: application/octet-stream"); //返回的文件
header('Content-type:application/x-www-form-urlencoded');//下载的文件类型信息(加了这个IOS的乱码文件问题)
header("Accept-Ranges: bytes"); //按照字节大小返回
header("Accept-Length: $file_size"); //返回文件大小
header( 'Content-Disposition: attachment; filename*=UTF-8\'\'' . rawurlencode($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;
}
ob_clean();
flush();
//关闭文件
fclose($fp);
}