摘要:文件上传 function upload_file($fileInfo,$uploadPath='./upload',$allowExt=['jpg','gif','png','jpeg','txt','sql'],$MaxSize=1000000) { &nbs
文件上传
function upload_file($fileInfo,$uploadPath='./upload',$allowExt=['jpg','gif','png','jpeg','txt','sql'],$MaxSize=1000000)
{
if ($fileInfo['error'] === 0){
// 获取文件后缀
$ext = strtolower(pathinfo($fileInfo['name'],PATHINFO_EXTENSION));
// 判断文件类型
if (!in_array($ext,$allowExt)){
return '非法文件类型!';
}
// 判断文件大小
if ($fileInfo['size']>$MaxSize){
return '超出文件上传最大值!';
}
// 判断文件上传方式
if (!is_uploaded_file($fileInfo['tmp_name'])){
return '非法上传';
}
// 判断需要移动到的目录是否存在
if (!is_dir($uploadPath)){
mkdir($uploadPath,0777,true);
}
// 生成唯一的文件名 uniqid 生成唯一id microtime 返回当前unix时间戳中的微秒
$uniName = md5(uniqid(microtime(true),true)) . '.' . $ext;
// 拼接路径以及文件名
$dest =$uploadPath.'/'.$uniName;
// 将文件移动到指定目录
if (!move_uploaded_file($fileInfo['tmp_name'],$dest)){
return '文件上传失败!';
}
return '文件上传成功!';
}else{
switch ($fileInfo['error']){
case 1:
$res = '上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值!';
break;
case 2:
$res = '上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值!';
break;
case 3:
$res = '文件只有部分被上传!';
break;
case 4:
$res = '没有文件被上传1';
break;
case 6:
$res = '找不到临时文件夹!';
break;
case 7:
$res = '文件写入失败';
break;
}
return $res;
}
}文件下载
/**
* 文件下载操作
* @param $filename //下载的文件名
*/
function down_file($filename){
//告诉浏览器返回的文件大小
header('Accept-Length:' . filesize($filename));
//告诉浏览器文件作为附件处理,并告诉浏览器下载完的文件名
header('Content-Disposition:attachment;filename=' . basename($filename));
//输出文件
readfile($filename);
exit();
}
//down_file('index.html');
批改老师:韦小宝批改时间:2019-01-18 11:17:09
老师总结:写的很详细 注释的也很完整 没事记得多研究 文件上传还是很重要的 这个操作需要考虑到很多的安全性