PHP中的$_FILES詳解

<form enctype="multipart/form-data" action="URL"method="post">
    <input type="file" name="brand_logo" />
</form>

wKiom1jwS4-zEGAmAAAnSz5MD2E184.png

在上傳圖片test1.png後,打印$_FILES數組,打印結果以下php

array (size=1)
  'brand_logo' => 
    array (size=5)
      'name' => string 'test1.png' (length=9)
      'type' => string 'p_w_picpath/png' (length=9)
      'tmp_name' => string 'J:\wamp\tmp\phpEA41.tmp' (length=23)
      'error' => int 0
      'size' => int 71194


$_FILES數組內容以下:html

$_FILES['myFile']['name'] 客戶端文件的原名稱      數組

$_FILES['myFile']['type'] 文件的 MIME類型,須要瀏覽器提供該信息的支持,例如"p_w_picpath/gif"      瀏覽器

$_FILES['myFile']['size'] 已上傳文件的大小,單位爲字節      ide

$_FILES['myFile']['tmp_name'] 文件被上傳後在服務端儲存的臨時文件名,通常是系統默認,能夠在php.iniupload_tmp_dir指定,但用 putenv() 函數設置是不起做用的    函數

$_FILES['myFile']['error'] 和該文件上傳相關的錯誤代碼,['error'] 是在 PHP 4.2.0版本中增長的,下面是它的說明:(它們在PHP3.0之後成了常量)post

UPLOAD_ERR_OK 值:0; 沒有錯誤發生,文件上傳成功spa

UPLOAD_ERR_INI_SIZE 值:1; 上傳的文件超過了php.ini upload_max_filesize選項限制的值          orm

UPLOAD_ERR_FORM_SIZE 值:2;上傳文件的大小超過了HTML 表單中 MAX_FILE_SIZE 選項指定的值      htm

UPLOAD_ERR_PARTIAL 值:3; 文件只有部分被上傳                

UPLOAD_ERR_NO_FILE 值:4;沒有文件被上傳, 值:5; 上傳文件大小爲0                     

注:

1. 文件被上傳結束後,默認地被存儲在了臨時目錄中,這時必須將它從臨時目錄中刪除或移動到其它地方,若是沒有,則會被刪除。也就是無論是否上傳成功,腳本執行完後臨時目錄裏的文件確定會被刪除。因此在刪除以前要用PHPcopy() 函數將它複製到其它位置,此時,纔算完成了上傳文件過程。

2. PHP 4.1.0 版本之前該數組的名稱爲$HTTP_POST_FILES,它並不像$_FILES 同樣是自動全局變量。PHP 3 不支持 $HTTP_POST_FILES數組。

3. form上傳文件時,必定要加上屬性內容enctype="multipart/form-data",不然用$_FILES[filename]獲取文件信息時會報異常。

代碼以下

<form enctype="multipart/form-data" action="URL"method="post">
       <input name="myFile" type="file">
       <input type="submit"value="上傳文件">
</form>
相關文章
相關標籤/搜索