溫馨提示×

溫馨提示×

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

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

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

發(fā)布時(shí)間:2021-08-31 14:31:19 來源:億速云 閱讀:151 作者:小新 欄目:開發(fā)技術(shù)

小編給大家分享一下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í)地址

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

錯(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è)資訊頻道!

向AI問一下細(xì)節(jié)

免責(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)容。

php
AI