<form enctype="multipart/form-data" action="URL"method="post"> <input type="file" name="brand_logo" /> </form>
在上傳圖片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.ini的upload_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. 文件被上傳結束後,默認地被存儲在了臨時目錄中,這時必須將它從臨時目錄中刪除或移動到其它地方,若是沒有,則會被刪除。也就是無論是否上傳成功,腳本執行完後臨時目錄裏的文件確定會被刪除。因此在刪除以前要用PHP的copy() 函數將它複製到其它位置,此時,纔算完成了上傳文件過程。
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>