$_FILES:經由 HTTP POST 文件上傳而提交至腳本的變量,類似於舊數組$HTTP_POST_FILES 數組(依然有效,但反對使用)詳細信息可參閱 POST方法上傳
$_FILES數組內容如下:
$_FILES['myFile']['name'] 客戶端文件的原名稱
$_FILES['myFile']['type'] 文件的 MIME類型,需要浏覽器提供該信息的支持,例如"image/gif"
$_FILES['myFile']['size'] 已上傳文件的大小,單位為字節
$_FILES['myFile']['tmp_name'] 文件被上傳後在服務端儲存的臨時文件名,一般是系統默認,可以在php.ini的upload_tmp_dir指定,但用 putenv() 函數設置是不起作用的
$_FILES['myFile']['error'] 和該文件上傳相關的錯誤代碼,['error'] 是在 PHP 4.2.0版本中增加的,下面是它的說明:(它們在PHP3.0以後成了常量)
UPLOAD_ERR_OK 值:0; 沒有錯誤發生,文件上傳成功
UPLOAD_ERR_INI_SIZE 值:1; 上傳的文件超過了 php.ini 中 upload_max_filesize選項限制的值
UPLOAD_ERR_FORM_SIZE 值:2;上傳文件的大小超過了 HTML 表單中 MAX_FILE_SIZE 選項指定的值
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>