php實作上傳圖片的方法:先建立儲存圖片的資料夾;然後建立HTML部分;接著建立一個php文件,並輸入程式碼為「」;最後透過PHP程式碼實作圖片上傳即可。
推薦:《PHP影片教學》
PHP 中的圖片上傳動作
前端程式設計中,有時需要允許瀏覽者上傳某張圖片,這樣的功能我們可以透過PHP 來實現。
一. 建立儲存圖片的資料夾
在這裡,我們建立資料夾「 file 」 來存放使用者上傳的圖片,此時資料夾是空的,資料夾建立位址可以自己選擇,但是最好建立在方便使用的位置。
二. 建立HTML 部分(uploadfile.html)
這裡我們使用了HTML 的form 表單標籤,以及表單中的
<input type="file">来选择图片文件 <input type="submit">来提交图片相关信息
程式碼如下:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> </head> <body> <form action="uploadHandler.php" method="post" enctype="multipart/form-data"> Upload Img:<input type="file" name="img"/> <input type="submit" value="Upload"/> </form> </body> </html>
注意:
1. form 表單裡的action 連接到之後會建立的處理圖片上傳的.php 檔案。
2. 在 form 的屬性中必須註明enctype="multipart/form-data"。 enctype 屬性規定在將表單資料傳送到伺服器之前如何對其進行編碼。 multipart/form-data不對字元編碼。當使用有文件上傳控制項的表單時,該值是必要的。
3. 在這裡,我們使用的是 post 方法。
三.建立PHP 部分(uploadHandler.php)
1. 原理
我們建立一個php 文件,在其中只輸入
<?php var_dump($_FILES); ?> 那么我们会打印到一个相应的数组arr(1)。 arr(1)的数组结构为: array(1) { ["img"]=> array(5) { ["name"]=> string(**) "AAAAAAA.jpg" // 图片名 ["type"]=> string(10) "image/jpeg" // 图片格式 ["tmp_name"]=> string(45) "/Applications/XAMPP/xamppfiles/temp/phpVZQY0m" // 图片缓存地址 ["error"]=> int(0) // 上传图片错误数 ["size"]=> int(124246) // 图片大小 } }
在array數組下有一個元素["img"] ,而在["img"] 下方是一個二維數組,這個二維數組有五個元素,分別為:name / type / tmp_name / error / size。
透過這幾個屬性我們得到了一個圖片的基本訊息,下一步我們要透過對這幾個基本屬性進行判斷而將圖片存進資料夾。
2. 實際操作
進行如下判斷:
error [有]:提示错误❌ error [无]:下一步✅ ╙type[非 img]:提示错误❌ ╙type[img]:下一步✅ ╙type[非 jpeg]:提示错误❌ ╙type[jpeg]:下一步✅
如果滿足如上的判斷,那麼我們認為這張圖片是可以保存的。
為避免圖片命名的重複,我們使用時間戳概念,拼接成一個新的檔案名,讓每張圖片的命名都是唯一的。
且我們可以創建一個數組,數組內的元素是各種圖片格式,將文件的圖片格式與數組中的元素進行比較,不是我們認可的圖片格式將不予保存。
程式碼如下:
<?php // 接收文件 var_dump($_FILES); // 区别于$_POST、$_GET print_r($_FILES); $file = $_FILES["img"]; // 先判断有没有错 if ($file["error"] == 0) { // 成功 // 判断传输的文件是否是图片,类型是否合适 // 获取传输的文件类型 $typeArr = explode("/", $file["type"]); if($typeArr[0]== "image"){ // 如果是图片类型 $imgType = array("png","jpg","jpeg"); if(in_array($typeArr[1], $imgType)){ // 图片格式是数组中的一个 // 类型检查无误,保存到文件夹内 // 给图片定一个新名字 (使用时间戳,防止重复) $imgname = "file/".time().".".$typeArr[1]; // 将上传的文件写入到文件夹中 // 参数1: 图片在服务器缓存的地址 // 参数2: 图片的目的地址(最终保存的位置) // 最终会有一个布尔返回值 $bol = move_uploaded_file($file["tmp_name"], $imgname); if($bol){ echo "上传成功!"; } else { echo "上传失败!"; }; }; } else { // 不是图片类型 echo "没有图片,再检查一下吧!"; }; } else { // 失败 echo $file["error"]; }; ?>
四. 上傳圖片
此時,如果各項都符合要求,那麼在file 資料夾內就存有了我們上傳的圖片。上傳成功!
以上是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 無盡。

熱門文章

熱工具

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

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

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

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

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