您好,登錄后才能下訂單哦!
小編給大家分享一下PHP文件上傳操作的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
具體如下:
文件上傳
發生在瀏覽器向服務器發出的請求中。
文件,對于瀏覽器來講,就是表單中的一個特殊類型的數據而已。
瀏覽器表單中的數據,兩種類型:
字符串類型(字節流編碼)
文件類型(二進制編碼),文件是表單數據中一部分
服務器角度:
在接受瀏覽器請求時,處理好表單內的數據。根據數據類型不同使用不同處理方法:
字符串類型,存儲在$_POST變量中(內存)
文件型數據,存儲在上傳臨時目錄中
表單提交時,瀏覽器會默認的行為:
表單內的的內容都是字符串類型,即使添加了文件域,需要在form上增加屬性,告知瀏覽器上傳的不止有字符串類型數據。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服務器在接收到文件類型的表單數據后,將文件存儲于臨時目錄(屬于臨時文件,腳本周期內有效)
; Temporary directory for HTTP uploaded files (will use system default if not ; specified). ; http://php.net/upload-tmp-dir ;upload_tmp_dir =
將臨時文件持久化存儲
move_uploaded_file(src_url,goa_url)
$_FILES,存儲了上傳文件的信息包括臨時地址
錯誤類型:
0-1-2-3-4-6-7
0表示沒有錯誤
1表示文件大于php的設置
; Maximum allowed size for uploaded files. ; http://php.net/upload-max-filesize upload_max_filesize = 2M
2表示文件大于表單設置max_file_size
<input type='hidden' name='MAX_FILE_SIZE' value='1024'>
3表示文件上傳不完整
4表示沒有上傳文件
5表示邏輯上上傳了0字節的文件(空文件)
6表示沒有找到臨時上傳目錄(權限不足)
7表示文件寫入失敗(磁盤空間、權限)
php允許的最大上傳文件數量
; 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的擴展fileinfo完成對文件信息的檢查(函數過程與面向對象)
;extension=php_fileinfo.dll
$finfo = new Finfo(FILEINFO_MIME_TYPE); $mine_type = $finfo->file($file['tmp_name']);
分子目錄存儲上傳文件
原則:業務邏輯、文件數量、時間
創建目錄 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; } //設置一個后綴名與mime的映射關系 $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]); } //瀏覽器提供信息堅持 $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; } //目錄存儲 $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文件上傳操作的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。