PHP單文件上傳原理及上傳函數的封裝
服務器(臨時文件)——>指定目錄,當文件進入服務器時它就是臨時文件了,這時操作中要用臨時文件的名稱tmp_name。
//在客戶端設置上傳文件的限制(文件類型和大小)是不安全的,因為客戶能通過源代碼修改限制,所以在服務端這裡設置限制。
//設置編碼為UTF-8,以避免中文亂碼
header('Content-Type:text/html;charset=utf-8');
//通過$_FILES接收上傳文件的信息
$fileInfo = $_FILES['myFile'];
function uploadFile($fileInfo,$uploadPath='uploads',$flag=true,$allowExt=array('jpeg','jpg','png','gif'),$maxSize = 2097152){
//判斷錯誤號,只有為0或者是UPLOAD_ERR_OK,沒有錯誤發生,上傳成功
if($fileInfo['error']>0){
//注意!錯誤信息沒有5
switch($fileInfo['error']){
case 1:
$mes= '上傳文件超過了PHP配置文件中upload_max_filesize選項的值';
break;
case 2:
$mes= '超過了HTML表單MAX_FILE_SIZE限制的大小';
break;
case 3:
$mes= '文件部分被上傳';
break;
case 4:
$mes= '沒有選擇上傳文件';
break;
case 6:
$mes= '沒有找到臨時目錄';
break;
case 7:
$mes= '文件寫入失敗';
break;
case 8:
$mes= '上傳的文件被PHP擴展程序中斷';
break;
}
exit($mes);
}
$ext=pathinfo($fileInfo['name'],PATHINFO_EXTENSION);
//$allowExt=array('jpeg','jpg','png','gif');
//檢測上傳文件的類型
if(in_array($ext,$allowExt)){
exit('非法文件類型');
}
//檢測上傳文的件大小是否符合規范
//$maxSize = 2097152;//2M
if($fileInfo['size']>$maxSize){
exit('上傳文件過大');
}
//檢測圖片是否為真實的圖片類型
//$flag=true;
if($flag){
if(!getimagesize($fileInfo['tmp_name'])){
exit('不是真實的圖片類型');
}
}
//檢測是否是通過HTTP POST方式上傳上來
if(!is_uploaded_file($fileInfo['tmp_name'])){
exit('文件不是通過HTTP POST方式上傳上來的');
}
//$uploadPath='uploads';
//如果沒有這個文件夾,那麼就創建一個
if(!file_exists($uploadPath)){
mkdir( $uploadPath, 0777, true);
chmod( $uploadPath, 0777 );
}
//新文件名唯一
$uniName = md5 ( uniqid( microtime(true),true) ).'.'.$ext;
$destination = $uploadPath.'/'.$uniName;
//@符號是為了不讓客戶看到錯誤信息
if(! @move_uploaded_file($fileInfo['tmp_name'], $destination )){
exit('文件移動失敗');
}
//echo '文件上傳成功';
//return array(
// 'newName'=>$destination,
// 'size'=>$fileInfo['size'],
// 'type'=>$fileInfo['type']
//);
return $destination;
}
?>