PHP如何實作檔案上傳
#1、表單部分
允許使用者上傳文件,在HTML表單的聲明中要加上一個上傳的屬性:
enctype = 'multipart/form-data'
表單的method必須是POST
表單選項MAX_FILE_SIZE隱藏域用於限制上傳檔案大小,它必須放在文件表單元素前面,單位為位元組。
程式碼如下:
<form enctype='multipart/form-data' id='aa' name='aaa' method='post' action='xxx.php'> <input type='hidden' name='MAX_FILE_SIZE' value='2621114' /> <input name='upload_file' type='file' /> </form>
相關推薦:《PHP入門教學》
2、處理上傳檔
#上傳時,PHP收到關於該檔案的資訊數組,這些資訊可以在$_FILES這個超級全域數組中找到。
如:如果表單中的檔案輸入框名稱為upload_file,那麼關於該檔案的所有資訊都包含在陣列$_FILES['upload_file']裡面。
如:客戶上傳了一個「aaa.jpg」的圖片陣列值如下:
name "p5pp.jpg" 上傳時檔案的名字
type “image/ jpeg" 檔案類型
tmp_name "/tmp/phpjksdf" 伺服器端的暫存檔案名稱
error 上傳錯誤的回傳值
#size 2045 檔案實際大小
# #上面陣列裡面的error會傳回不同的常數值,如下:
UPLOAD_ERR_OK 沒有錯誤發生,檔案上傳成功
UPLOAD_ERR_INI_SIZE 檔案大小超過了PHP.INIupload_max_filesize選項限制的值
UPLOAD_ERR_FORM_SIZE 上傳檔案的大小超過了HTML表單中MAX_FILE_SIZE選項值。可在程序中檢查表單$FILES ['up_file']['size']來處理
UPLOAD_ERR_PARTIAL 文件只有部分被上傳
UPLOAD_ERR_NO_FILE 用戶沒有提供任何文件上傳
上傳後處理的具體範例:
程式碼如下:
if(!move_uploaded_file($_FILES['f']['tmp_name'],"uploads/".$_FILES['f']['name'].".jpg")){ echo "error"; }
函數:
move_uploaded_file 移動上傳的暫存檔案到指定的目錄下
#範例:
move_uploaded_file('暫存檔名稱','指定檔案路徑')
is_uploaded_file 判斷是否為透過http Post上傳的檔案
#範例:
程式碼如下:
if(!is_uploaded_file($_FILES['f']['tmp_name'])){ echo '非法'; }
3、相關參數
PHP上傳設計到的php.ini中的參數:
#file_uploads 是否允許上傳文件,預設ON。
upload_tmp_dir 上傳檔案防止的暫存目錄,未指定則使用系統預設位置。
upload_max_filesize 允許上傳檔案的大小的最大值,預設為2M。
post_max_size 控制採用POST方法進行一次表單提交中PHP所能接受的最大資料量,如果希望用PHP檔案上傳,則此值要改為比upload_max_filesize要大。
max_input_time 以秒為單位對透過POST/GET/PUT方式接受資料時間進行限制。
memory_limit 為了避免正在執行的腳本大量使用系統內存,PHP允許定義記憶體使用限額。透過設定此參數來制定單一腳本程式可以使用的最大記憶體容量,應適當大於post_max_size值。
max_execution_time 用來設定在強制終止腳本前PHP等待腳本執行完畢的時間,單位秒。次選項可限制死循環腳本,但當存在長時間的合法活動時(如:上傳大檔案),這項功能也會導致操作失敗。這樣情況下必須考慮將此變數增加。
4、考慮多檔案上傳
可以利用$_FILES陣列就可以輕鬆實現多檔案上傳。 $_FILES陣列可以取得客戶端表單裡面所有的file域內容,從而獲得所有在同一表單上傳的檔案。
5、突破上傳的記憶體限制
方法一:
修改php.ini中memory_limit值,改為更大,如64M
方法二:
使用Apache Rewrite方法,動態修改memory_limit的值。先建立一個.htaccess文件,儲存在上傳文件程式的 目前目錄即可。
程式碼如下:
php_value memory_limit 100M php_value post_max_size 30M php_value upload_max_filesize 30M php_value max_execution_time 300 php_value max_input_tim 300 php_value display_errors On
以上是php怎麼實作上傳檔案功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本文比較了酸和基本數據庫模型,詳細介紹了它們的特徵和適當的用例。酸優先確定數據完整性和一致性,適合財務和電子商務應用程序,而基礎則側重於可用性和

本文討論了確保PHP文件上傳的確保,以防止諸如代碼注入之類的漏洞。它專注於文件類型驗證,安全存儲和錯誤處理以增強應用程序安全性。

本文討論了在PHP中實施API速率限制的策略,包括諸如令牌桶和漏水桶等算法,以及使用Symfony/Rate-limimiter之類的庫。它還涵蓋監視,動態調整速率限制和手

本文討論了使用password_hash和pyspasswify在PHP中使用密碼的好處。主要論點是,這些功能通過自動鹽,強大的哈希算法和SECH來增強密碼保護

本文討論了OWASP在PHP和緩解策略中的十大漏洞。關鍵問題包括注射,驗證損壞和XSS,並提供用於監視和保護PHP應用程序的推薦工具。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

Dreamweaver Mac版
視覺化網頁開發工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。