php文件上傳流程:首先配置PHP文件,並設定前端表單;然後將臨時文件預設保存在所設定的目錄下;接著對file數組中的error屬性進行判斷處理;最後在前端可以對上傳的文件類型,大小進行限制。
本教學操作環境:windows7系統、PHP5.6版,DELL G3電腦,此方法適用於所有品牌電腦。
php檔案上傳流程:
1、php設定檔
php.ini檔案中的file uploads部分定義了相關檔案上傳配置,
file_uploads = On 開啟檔案上傳
upload_tmp_dir =臨時目錄
upload_max_filesize = 2M最大上傳大小
max_file_uploads = 20單次最大上傳檔案數
2、前端表單
<form action="test.php" method="post" enctype="multipart/form-data"> <input type="file" name="myfile"> <input type="submit" value="上传"> </form>
當使用由文件上傳控制項的表單時,必須將form的enctype設定為"multipart/form-data"。
可以在客戶端對上傳檔案的大小與類型進行限制:
<input type="hidden" name="MAX_FILE_SIZE" value="8096"> <input type="file" name="myfile" accept="image/jpeg,image/png">
3、後台處理
上傳後會在伺服器端得到一個$_FILES
檔案陣列如下:
上傳到伺服器的暫存檔案預設保存在php.ini中upload_tmp_dir
所設定的目錄下,我們需要將檔案移到指定位置:
<?php header('Content-type:text/html;charset=utf-8'); $myfile=$_FILES['myfile']; //获取文件数组['myfile']的属性tmp_name与name $tmp=$myfile['tmp_name']; $picname=$myfile['name']; //windows采用GBK编码,php采用utf-8编码,需要改变文件名的编码格式 $picname=iconv('utf-8','GBK',$picname); //将零时文件$tmp移动到指定目录userpic并命名为$picname copy($tmp,"userpic/".$picname);
4、錯誤處理
對file數組中的error屬性進行判斷處理:
$error=$myfile['myfile']['error']; if ($error==0){//为0,代表上传成功 if (move_uploaded_file($tmp,"userpic/".$picname)) { echo "移动文件成功"; }else{ echo "移动文件失败"; } }else{//不为0,匹配错误信息 switch ($error){ case 1: echo "超过文件最大上传限制";//php.ini中upload_max_filesize break; case 2: echo "超过表单文件大小限制";//HTML表单中MAX_FILE_SIZE选项 break; case 3: echo "文件部分被上传"; break; case 4: echo "未选择上传文件"; break; case 7://文件写入失败 case 8: echo "系统错误"; break; } }
5、上傳限制
#在前端可以對上傳的檔案類型,大小進行限制:
<!--表单隐藏域对上传大小进行限制--> <input type="hidden" name="MAX_FILE_SIZE" value="2097152"> <!--accept 对文件类型限制--> <input type="file" name="myfile" accept="image/jpeg,image/png">
注意限制是以位元組為單位
在伺服器端也要做回應的限制:
$size=$myfile['size'];//获取文件大小 $MaxSize=2097152;//设置最大允许字节 $type=$myfile['type'];//获取图片类型 $AllowTypr=array('image/jpeg','image/png','image/gif');//允许类型数组 if ($error==0){//为0,代表上传成功 if ($size>$MaxSize){ echo "<script>alert('文件大小超过限制');</script>"; echo "<script>history.back(1);</script>"; exit(); } if (!in_array($type,$AllowTypr)){ echo "<script>alert('请上传正确图片类型');</script>"; echo "<script>history.back(1);</script>"; exit(); }
相關影片推薦:PHP程式設計從入門到精通
以上是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 無盡。

熱門文章

熱工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

WebStorm Mac版
好用的JavaScript開發工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

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

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中