private function secureCheck($file)
{
//文件上传失败,检查错误码
if ($file['error'] != 0) {
switch ($file['error']) {
case 1:
$this->errorInfo = '上传的文件大小超过了 php.ini 中 upload_max_filesize 选项限制的值';
break;
case 2:
$this->errorInfo = '上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值';
break;
case 3:
$this->errorInfo = '文件只有部分被上传';
break;
case 4:
$this->errorInfo = '没有文件被上传';
break;
case 6:
$this->errorInfo = '找不到临时文件夹';
break;
case 7:
$this->errorInfo = '文件写入失败';
break;
default:
$this->errorInfo = '未知上传错误!';
}
return false;
}
//文件上传成功,进行自定义检查
if (-1 != $this->config['maxSize'] && $file['size'] > $this->config['maxSize']) {
$this->errorInfo = '上传文件大小不符';
return false;
}
//检查文件Mime类型
if (!$this->checkType($file['type'])) {
$this->errorInfo = '上传文件mime类型允许';
return false;
}
//检查文件类型
if (!$this->checkExt($file['extension'])) {
$this->errorInfo = '上传文件类型不允许';
return false;
}
//检查是否合法上传
if (!is_uploaded_file($file['tmp_name'])) {
$this->errorInfo = '非法的上传文件!';
return false;
}
return true;
}