(1)、在
標籤中將enctype和method兩個屬性指明相應的值。
Enctype="multipart/form-data"; Method="POST"
(2)、form表單中設定一個hidden類型的input框,其中name的值為MAX_FILE_SIZE的隱藏值
2、伺服器端設定:
(1)、$_FILES多維陣列:用於儲存各種上傳檔案有關的資訊
(2)、檔案上傳與php設定檔的設定,如以下php.ini檔案中的一些指令
指令 預設值 功能描述
file_uploads ON 確定伺服器上的PHP指令碼是否可以接受HTTP檔案上傳
memory_limit 8M 設定指令碼可以分配的最大記憶體量,防止失控的指令碼獨佔伺服器記憶體
upload_max_file 2M 限制PHP處理上傳檔案大小的最大值,此值必須小於POST_MAX_SIZE值
post_max_size 8M 限制通過POST方法可以接受資訊的最大值
upload_tmp_dir NULL 上傳檔案的臨時路徑,可以是一個絕對路徑
-
3、PHP的檔案上傳及資源指令
file_uploads(boolean)
是否開啟HTTP POST檔案上傳功能
max_execution_time(integer)
PHP指令碼最長執行時間
memory_limit(integer) 單位M
PHP指令碼啟動並執行最大記憶體
upload_max_filesize(integer) 單位M
PHP上傳檔案的最大尺寸
upload_tmp_dir(string)
上傳檔案儲存體的臨時位置
post_max_size(integer) 單位M
HTTP POST資料的最大尺寸
4、$_FILES數組
$_FILES['userfile'][size]
擷取上傳檔案的位元組數
$_FILES['userfile']['type']
擷取上傳檔案的MIME類型,每種MIME類型都是由“/”分隔的主類型和子類型組成
$_FILES['userfile']['error']
擷取上傳檔案的錯誤碼,0:無任何錯誤,檔案上傳成功;1:上傳檔案大小超出了PHP設定檔中upload_max_filesize選項限定的值;2:上傳檔案大小超出了HTML表單中MAX_FILE_SIZE指定的值;3:表示檔案只被部分上傳;4:表示沒有上傳任何檔案。
$_FILES['userfile']['name']
擷取上傳檔案的原始名稱,包含副檔名
$_FILES['userfile']['tmp_name']
擷取上傳檔案的臨時位置名稱,這是儲存在臨時目錄中所指定的檔案名稱。
5、檔案上傳函數
is_upload_file
判斷指定的檔案是否是通過HTTP POST上傳
bool is_upload_file(string $filename)
move_upload_file
將上傳檔案移至新位置
bool move_upload_file(string $filename, string $destination)
注意:檔案上傳後,首先會儲存於伺服器的臨時目錄中,可以使用該函數將上傳檔案移動到新位置,與copy()和move()相比,它能檢測並確保第一個參數filename指定的檔案是否是合法上傳的檔案。
6、錯誤資訊描述
UPLOAD_ERR_OK{value=0}
UPLOAD_ERR_INI_SIZE{value=1}
UPLOAD_ERR_FORM_SIZE{value=2}
UPLOAD_ERR_PARTIAL{value=3}
UPLOAD_ERR_NO_FILE{value=4}
UPLOAD_ERR_NO_TMP_DIR{value=6}
UPLOAD_ERR_CANT_WRITE{value=7}