91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHP文件上傳操作的示例分析

發布時間:2021-08-31 14:31:19 來源:億速云 閱讀:153 作者:小新 欄目:開發技術

小編給大家分享一下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,存儲了上傳文件的信息包括臨時地址

PHP文件上傳操作的示例分析

錯誤類型:

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文件上傳操作的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

php
AI

廊坊市| 浑源县| 习水县| 三都| 承德市| 沙河市| 怀柔区| 崇明县| 莱西市| 手机| 许昌市| 南投县| 新郑市| 商洛市| 闽侯县| 五华县| 大同县| 柏乡县| 泰和县| 兴业县| 白河县| 南郑县| 沧源| 定襄县| 阿荣旗| 台安县| 滨海县| 张北县| 临夏县| 枣阳市| 杨浦区| 和田县| 兖州市| 南昌县| 松江区| 鄂伦春自治旗| 云浮市| 大洼县| 罗城| 龙南县| 探索|