檔案上傳原則
#將客戶端的檔案上傳到伺服器,再將伺服器的暫存檔案上傳到指定目錄
客戶端設定
提交表單
表單的傳送方式為post
新增enctype="multipart/form-data"
伺服器端設定(建議學習:PHP程式設計從入門到精通)
file_uploads = On,支援HTTP上傳
uoload_tmp_dir = ,暫存檔案儲存目錄
upload_max_filesize = 2M,允許上傳檔案的最大值
max_file_uploads = 20 ,允許一次上傳到的最大檔案數
post_max_size = 8M,post方式傳送資料的最大值
max_execution_time = -1,設定了腳本被解析器終止之前允許的最大執行時間,單位為秒,防止程式寫的不好而佔盡伺服器資源。 -1代表無窮
max_input_time = 60 ,腳本解析輸入資料允許的最大時間,單位為秒
max_input_nesting_level = 64 ,設定輸入變數的巢狀深度
max_input_vars_ = 1000,接受多少輸入的變數(限制分別應用於$_GET、$_POST和$_COOKIE超全域變量,將會導致E_WARNING的產生,更多的輸入變數將會從請求中截斷。
memory_limit = 128M,最大單線程的獨立記憶體使用量。也就是一個web請求,給予線程最大的記憶體使用量的定義
錯誤訊息說明
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,沒有檔案被上傳
UPLOAD_ERR_NO_TMP_DIR:其值為6,找不到臨時資料夾
UPLOAD_ERR_CANT_WRITE:其值為7,檔案寫入失敗
#UPLOAD_ERR_EXTENSION:其值為8 ,上傳的檔案被PHP擴充功能中斷
客戶端限制
#透過表單隱藏網域限製檔案上傳檔案的最大值
<input type='hidden' name='MAX_FILE_SIZE' VALUE='字节数' />
透過accept屬性限制上傳檔案類型
<input type='file' name='myFile' accept='文件的MIME类型' />
在客戶端的限制,使用者可在網頁上修改程式碼後上傳,故無實際意義。應在伺服器端加以限制
#限制上傳檔案的大小
限制上傳檔案類型
偵測是否為真實圖片類型
偵測是否為HTTP POST方式上傳
#以上是php上傳文件的原理的詳細內容。更多資訊請關注PHP中文網其他相關文章!