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){//注意!錯誤信息沒有5switch($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;//2Mif($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;[email?protected]if(! @move_uploaded_file($fileInfo['tmp_name'], $destination )){exit('文件移動失敗');}//echo '文件上傳成功';//return array(//'newName'=>$destination,//'size'=>$fileInfo['size'],//'type'=>$fileInfo['type']//);return $destination;}?>
相關文章
相關視頻