首頁  >  文章  >  後端開發  >  php上傳文件的原理

php上傳文件的原理

(*-*)浩
(*-*)浩原創
2019-09-07 14:47:333186瀏覽

php上傳文件的原理

檔案上傳原則

#將客戶端的檔案上傳到伺服器,再將伺服器的暫存檔案上傳到指定目錄

客戶端設定

提交表單

表單的傳送方式為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=&#39;hidden&#39; name=&#39;MAX_FILE_SIZE&#39; VALUE=&#39;字节数&#39; />

透過accept屬性限制上傳檔案類型

<input type=&#39;file&#39; name=&#39;myFile&#39; accept=&#39;文件的MIME类型&#39; />

在客戶端的限制,使用者可在網頁上修改程式碼後上傳,故無實際意義。應在伺服器端加以限制

#限制上傳檔案的大小

限制上傳檔案類型

偵測是否為真實圖片類型

偵測是否為HTTP POST方式上傳

#

以上是php上傳文件的原理的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn