您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關PHP怎樣實現單文件、多個單文件、多文件上傳函數的封裝的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
本文實例講述了PHP實現單文件、多個單文件、多文件上傳函數的封裝。分享給大家供大家參考,具體如下:
表單:
s.php
要在選擇上傳文件時能一次選擇多個文件,那么就加multiple="multiple"
,還有注意下name="myFile1"
和name="myFile[]"
的區別,單文件、多文件上傳.
<!doctype html> <html> <head> <meta charset="utf-8"> <title>無標題文檔</title> </head> <body> <form action="sss.php" method="post" enctype="multipart/form-data"> <input type="file" name="myFile1" /><br/> <input type="file" name="myFile2" /><br/> <input type="file" name="myFile[]" /><br/> <input type="file" name="myFile[]" /><br/> <input type="file" name="myFile[]" multiple="multiple"/><br/> <input type="submit" value="上傳文件"/> </form> </body> </html>
上傳函數的封裝:
ss.php
<?php header('Content-Type:text/html;charset=utf-8'); //構建上傳文件信息 function getFiles(){ $i=0; foreach($_FILES as $file){ //因為這時$_FILES是個三維數組,并且上傳單文件或多文件時,數組的第一維的類型不同,這樣就可以拿來判斷上傳的是單文件還是多文件 if(is_string($file['name'])){ //如果是單文件 $files[$i]=$file; $i++; }elseif(is_array($file['name'])){ //如果是多文件 foreach($file['name'] as $key=>$val){ $files[$i]['name']=$file['name'][$key]; $files[$i]['type']=$file['type'][$key]; $files[$i]['tmp_name']=$file['tmp_name'][$key]; $files[$i]['error']=$file['error'][$key]; $files[$i]['size']=$file['size'][$key]; $i++; } } } return $files; } //針對于單文件、多個單文件、多文件的上傳 //默認允許上傳的文件只為圖片類型,并且只有這些圖片類型:$allowExt=array('jpeg','jpg','png','gif');并且檢查上傳的文件是否為真實的圖片$flag=true //默認上傳保存的文件夾為本地的'uploads'文件夾,允許上傳文件的大小最大為2M function uploadFile($fileInfo,$path='./uploads',$flag=true,$allowExt=array('jpeg','jpg','png','gif'),$maxSize=2097152){ //判斷錯誤號 if($fileInfo['error']===UPLOAD_ERR_OK){ //檢測上傳文件的大小 if($fileInfo['size']>$maxSize){ $res['mes']=$fileInfo['name'].'上傳文件過大'; } $ext=getExt($fileInfo['name']); //檢測上傳文件的文件類型 if(!in_array($ext,$allowExt)){ $res['mes']=$fileInfo['name'].'非法文件類型'; } //檢測是否是真實的圖片類型 if($flag){ if(!getimagesize($fileInfo['tmp_name'])){ $res['mes']=$fileInfo['name'].'不是真實圖片類型'; } } //檢測文件是否是通過HTTP POST上傳上來的 if(!is_uploaded_file($fileInfo['tmp_name'])){ $res['mes']=$fileInfo['name'].'文件不是通過HTTP POST方式上傳上來的'; } if( $res ) return $res; //如果要不顯示錯誤信息的話,用if( @$res ) return $res; //$path='./uploads'; //如果沒有這個文件夾,那么就創建一 if(!file_exists($path)){ mkdir($path,0777,true); chmod($path,0777); } //新文件名唯一 $uniName=getUniName(); $destination=$path.'/'.$uniName.'.'.$ext; //@符號是為了不讓客戶看到錯誤信,也可以刪除 if(!@move_uploaded_file($fileInfo['tmp_name'],$destination)){ $res['mes']=$fileInfo['name'].'文件移動失敗'; } $res['mes']=$fileInfo['name'].'上傳成功'; $res['dest']=$destination; return $res; }else{ //匹配錯誤信息 //注意!錯誤信息沒有5 switch($fileInfo['error']){ case 1: $res['mes'] = '上傳文件超過了PHP配置文件中upload_max_filesize選項的值'; break; case 2: $res['mes'] = '超過了HTML表單MAX_FILE_SIZE限制的大小'; break; case 3: $res['mes'] = '文件部分被上傳'; break; case 4: $res['mes'] = '沒有選擇上傳文件'; break; case 6: $res['mes'] = '沒有找到臨時目錄'; break; case 7: $res['mes'] = '文件寫入失敗'; break; case 8: $res['mes'] = '上傳的文件被PHP擴展程序中斷'; break; } return $res; } } ?>
common.ss.php
<?php //這兩函數也可以一起放到ss.php里面去 //得到文件擴展名 function getExt($filename){ return strtolower(pathinfo($filename,PATHINFO_EXTENSION)); } //產生唯一字符串 function getUniName(){ return md5(uniqid(microtime(true),true)); } ?>
上傳后文件的操作:
<?php header("content-type:text/html;charset=utf-8"); require_once 'ss.php'; require_once 'common.ss.php'; $files=getFiles(); //修改允許上傳文件的類型,為('jpeg','jpg','png','gif','html','txt'),也可以增加新的,如pdf,pptx等等 $allowExt=array('jpeg','jpg','png','gif','html','txt'); foreach($files as $fileInfo){ //修改上傳保存的文件夾為本地的'imooc',如果沒有這個文件夾,那么就創建一個 //'false'參數:不要檢查上傳的文件是否為真實的圖片,因為要允許上傳除開圖片類型外的其他類型文件,如html、txt $res=uploadFile($fileInfo,'imooc',false,$allowExt); echo $res['mes'],'<br/>'; $uploadFiles[]=$res['dest'];//如果要不顯示錯誤信息的話,用@$uploadFiles[]=$res['dest']; } $uploadFiles=array_values(array_filter($uploadFiles));//這樣便于保存到數據庫 print_r($uploadFiles);//打印查看上傳保存的結果 ?>
感謝各位的閱讀!關于“PHP怎樣實現單文件、多個單文件、多文件上傳函數的封裝”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。