您好,登錄后才能下訂單哦!
小編給大家分享一下PHP文件上傳操作的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
具體如下:
文件上傳
發(fā)生在瀏覽器向服務(wù)器發(fā)出的請求中。
文件,對于瀏覽器來講,就是表單中的一個(gè)特殊類型的數(shù)據(jù)而已。
瀏覽器表單中的數(shù)據(jù),兩種類型:
字符串類型(字節(jié)流編碼)
文件類型(二進(jìn)制編碼),文件是表單數(shù)據(jù)中一部分
服務(wù)器角度:
在接受瀏覽器請求時(shí),處理好表單內(nèi)的數(shù)據(jù)。根據(jù)數(shù)據(jù)類型不同使用不同處理方法:
字符串類型,存儲(chǔ)在$_POST變量中(內(nèi)存)
文件型數(shù)據(jù),存儲(chǔ)在上傳臨時(shí)目錄中
表單提交時(shí),瀏覽器會(huì)默認(rèn)的行為:
表單內(nèi)的的內(nèi)容都是字符串類型,即使添加了文件域,需要在form上增加屬性,告知瀏覽器上傳的不止有字符串類型數(shù)據(jù)。enctype="multipart/form-data"
<body> <form action="upload.php" method="post" enctype="multipart/form-data"> <input type="file" name="file"> </br> <input type="submit" value="submit"> </form> </body>
php服務(wù)器在接收到文件類型的表單數(shù)據(jù)后,將文件存儲(chǔ)于臨時(shí)目錄(屬于臨時(shí)文件,腳本周期內(nèi)有效)
; Temporary directory for HTTP uploaded files (will use system default if not ; specified). ; http://php.net/upload-tmp-dir ;upload_tmp_dir =
將臨時(shí)文件持久化存儲(chǔ)
move_uploaded_file(src_url,goa_url)
$_FILES,存儲(chǔ)了上傳文件的信息包括臨時(shí)地址
錯(cuò)誤類型:
0-1-2-3-4-6-7
0表示沒有錯(cuò)誤
1表示文件大于php的設(shè)置
; Maximum allowed size for uploaded files. ; http://php.net/upload-max-filesize upload_max_filesize = 2M
2表示文件大于表單設(shè)置max_file_size
<input type='hidden' name='MAX_FILE_SIZE' value='1024'>
3表示文件上傳不完整
4表示沒有上傳文件
5表示邏輯上上傳了0字節(jié)的文件(空文件)
6表示沒有找到臨時(shí)上傳目錄(權(quán)限不足)
7表示文件寫入失?。ù疟P空間、權(quán)限)
php允許的最大上傳文件數(shù)量
; Maximum number of files that can be uploaded via a single request max_file_uploads = 20
post存在最大值限制
一旦超過,php就不能正常處理post與file值可能為空值
; Maximum size of POST data that PHP will accept. ; http://php.net/post-max-size post_max_size = 8M
類型檢測中
后綴名與mime都是瀏覽器提供的,需要php的擴(kuò)展fileinfo完成對文件信息的檢查(函數(shù)過程與面向?qū)ο螅?/p>
;extension=php_fileinfo.dll
$finfo = new Finfo(FILEINFO_MIME_TYPE); $mine_type = $finfo->file($file['tmp_name']);
分子目錄存儲(chǔ)上傳文件
原則:業(yè)務(wù)邏輯、文件數(shù)量、時(shí)間
創(chuàng)建目錄 mkdir()
檢查目錄 is_dir()
<?php upload($_FILES['file']); function upload($file){ if($file['error']!=0){ return false; } //3M $max_size = 3145728; if($max_size<$file['size']){ return false; } //設(shè)置一個(gè)后綴名與mime的映射關(guān)系 $type_map = array( '.jpeg'=>array('image/jpeg','image/pjpeg'), '.jpg'=>array('image/jpeg','image/pjpeg'), '.png'=>array('image/png','image/x-png'), '.gif'=>array('image/gif') ); //后綴 $allow_ext_list = array('.jpeg','.png','.jpg'); $ext = strtolower(strrchr($file['name'],'.')); if(!in_array($ext,$allow_ext_list)){ echo '不支持該圖片格式'; return false; } //MIME $allow_mime_list = array(); foreach($allow_ext_list as $val){ $allow_mime_list = array_merge($allow_mime_list,$type_map[$val]); } //瀏覽器提供信息堅(jiān)持 $allow_mime_list = array_unique($allow_mime_list); if(!in_array($file['type'],$allow_mime_list)){ echo '不支持該圖片格式'; return false; } //php自身檢查 $file_mime = new Finfo(FILEINFO_MIME_TYPE); $mime = $file_mime->file($file['tmp_name']); if(!in_array($mime,$allow_mime_list)){ echo '不支持該圖片格式'; return false; } //目錄存儲(chǔ) $up_loadpath = './'; $sub_dir = date('Ymdh'); if(!is_dir($up_loadpath.$sub_dir)){ mkdir($up_loadpath.$sub_dir); } $prefix = 'bee_'; $name = uniqid($prefix,true).$ext; if(move_uploaded_file($file['tmp_name'],$up_loadpath.$sub_dir.$name)){ echo '上傳成功'; return $name; }else{ echo '上傳失敗'; return false; } }
以上是“PHP文件上傳操作的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。