PHP實(shí)現(xiàn)本地圖片上傳和驗(yàn)證功能
今天研究了一下PHP的FILES函數(shù),使用PHP實(shí)現(xiàn)本地圖片的上傳,驗(yàn)證文件是否為圖片,并將圖片保存在指定目錄下,實(shí)現(xiàn)游覽圖片的功能,感覺(jué)還是很好玩的,一共有兩個(gè)PHP頁(yè)面,一個(gè)作為前臺(tái)的上傳和圖片展示,另一個(gè)用來(lái)處理保存圖片,代碼里做了很詳細(xì)的注釋,并將FILES函數(shù)的語(yǔ)法,error報(bào)錯(cuò)類型寫(xiě)了出來(lái),還有一些注意事項(xiàng)。
FILES函數(shù)
1、$_FILES[‘myFile'][‘name'] 客戶端文件的原名稱
2、$_FILES[‘myFile'][‘type'] 文件的 MIME類型,需要瀏覽器提供該信息的支持,例如”image/gif”
3、$_FILES[‘myFile'][‘size'] 已上傳文件的大小,單位為字節(jié)
4、$_FILES[‘myFile'][‘tmp_name'] 文件被上傳后在服務(wù)端儲(chǔ)存的臨時(shí)文件名,一般是系統(tǒng)默認(rèn),可以在php.ini的upload_tmp_dir指定
關(guān)于FILES中error報(bào)錯(cuò)類型及其注意:
過(guò)濾錯(cuò)誤號(hào)
0: 沒(méi)有錯(cuò)誤發(fā)生,文件上傳成功
1: 上傳的文件超過(guò)了 php.ini 中 upload_max_filesize選項(xiàng)限制的值
2: 上傳文件的大小超過(guò)了 HTML 表單中 MAX_FILE_SIZE 選項(xiàng)指定的值
3: 文件只有部分被上傳
4: 沒(méi)有文件被上傳
5: 上傳文件大小為0
注意:
1、文件被上傳結(jié)束后,默認(rèn)地被存儲(chǔ)在了臨時(shí)目錄中,這時(shí)必須將它從臨時(shí)目錄中刪除或移動(dòng)到其它地方,如果沒(méi)有,則會(huì)被刪除。也就是不管是否上傳成功,腳本執(zhí)行完后臨時(shí)目錄里的文件肯定會(huì)被刪除。所以在刪除之前要用PHP的copy() 函數(shù)將它復(fù)制到其它位置,此時(shí),才算完成了上傳文件過(guò)程。
2、在 PHP 4.1.0 版本以前該數(shù)組的名稱為$HTTP_POST_FILES,它并不像_FILES 一樣是自動(dòng)全局變量。PHP 3 不支持HTTP_POST_FILES數(shù)組。
3、用form上傳文件時(shí),一定要加上屬性內(nèi)容enctype=”multipart/form-data”,否則用$_FILES[filename]獲取文件信息時(shí)會(huì)報(bào)異常。
以下是代碼
index.php
<?php header("Content-Type:text/html;charset=utf-8"); ?> <title>PHP實(shí)現(xiàn)圖片的上傳和驗(yàn)證</title> <style> table{text-align:center;} </style> <div align="center"> <h1>上傳功能</h1> <form action="index_ok.php" method="post" enctype="multipart/form-data"> 上傳圖片:<input type="file" name="pic"> <input type="submit" name="sub" value="上傳"> </form> <table width="500"> <tr bgcolor="#cccccc"> <th>序號(hào)</th> <th>圖片</th> <th>添加時(shí)間</th> <th>操作</th> </tr> <?php //1 打開(kāi)目錄 $dir=opendir("./uploads"); //2 遍歷目錄,輸出里面的圖片 $i=0; while($f=readdir($dir)){ $i++; //讀取目錄中的文件,模擬數(shù)據(jù)庫(kù)操作 if($f!="." && $f!=".."){ $filename="./uploads/$f"; echo "<tr>"; echo "<td>{$i}</td>"; echo "<td><img src='./uploads/{$f}' width='80' height='60'></td>"; echo "<td>".date("Y-m-d",filectime($filename))."</td>"; echo "<td><a href='./uploads/{$f}'>查看</a></td>"; echo "</tr>"; } } //3 關(guān)閉目錄 closedir($dir); ?> <tr bgcolor="#cccccc"><td colspan="4"> </td></tr> </table> </div>
upload.php
<?php header("Content-Type:text/html;charset=utf-8"); if($_FILES['pic']['error']>0){ echo $_FILES['pic']['error']; echo "上傳文件錯(cuò)誤!"; echo '<meta http-equiv="refresh" content="3;url=index.php">'; //自動(dòng)跳轉(zhuǎn)回index文件 }else{ //開(kāi)始獲取上傳文件的信息 $file=$_FILES['pic']; //var_dump($file);打印文件里的全部信息 //name:上傳文件名 //type:上傳文件的類型 //tmp_name:上傳成功后的臨時(shí)文件 //size:上傳文件的大小 //error:上傳文件的錯(cuò)誤信息 $uploaddir="./uploads/"; //選擇要上傳的文件存放目錄 //$uploadfile=$uploaddir.basename($file['name']);//獲得上傳文件的名稱 //解析文件的名字 $fileinfo=pathinfo($file['name']); // echo $fileinfo['extension']; 獲取文件的類型 do{ $newfile=date("YmdHis").rand(1000,9999).".".$fileinfo['extension'];//更改文件的名字,獲取一個(gè)新的名字 }while(file_exists($uploaddir.$newfile)); //上傳文件的類型限制 if (!(($file['type'] == "image/gif")||($file['type'] == "image/jpeg")||($file['type'] == "image/pjpeg"))){ die("文件類型錯(cuò)誤!"); echo '<meta http-equiv="refresh" content="3;url=index.php">'; } //上傳文件的大小限制 if($file['size'] > 2*1024*1024){ die("上傳文件超過(guò)2MB!"); echo '<meta http-equiv="refresh" content="3;url=index.php">'; } //開(kāi)始上傳文件 if (is_uploaded_file($file['tmp_name'])) { if (move_uploaded_file($file['tmp_name'], $uploaddir.$newfile)) { echo "上傳成功!"; echo '<meta http-equiv="refresh" content="3;url=index.php">';//自動(dòng)跳轉(zhuǎn)回index文件 } else { echo "上傳失敗,請(qǐng)稍等!"; echo '<meta http-equiv="refresh" content="3;url=index.php">'; //自動(dòng)跳轉(zhuǎn)回index文件 } } } ?>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Bootstrap項(xiàng)目實(shí)戰(zhàn)之首頁(yè)內(nèi)容介紹(全)
本文分為兩部分介紹Bootstrap首頁(yè)內(nèi)容介紹的實(shí)現(xiàn)代碼,感興趣的小伙伴們可以參考一下2016-04-04深入探究使JavaScript動(dòng)畫(huà)流暢的一些方法
這篇文章主要介紹了使JavaScript動(dòng)畫(huà)流暢的一些方法,包括與CSS動(dòng)畫(huà)效果的一些對(duì)比,需要的朋友可以參考下2015-06-06JavaScript設(shè)計(jì)模式組合設(shè)計(jì)模式案例
這篇文章主要介紹了JavaScript設(shè)計(jì)模式組合設(shè)計(jì)模式案例,組合設(shè)計(jì)模式是用于將多個(gè)部分通過(guò)組合的方式行成一個(gè)整體,更多相關(guān)內(nèi)容需要的小伙伴可以參考一下2022-06-06JavaScript 事件冒泡應(yīng)用實(shí)例分析
在一些傳統(tǒng)的小型WEB應(yīng)用開(kāi)發(fā)過(guò)程中,JavaScript通常只是拿來(lái)做表單驗(yàn)證而以,所以你很少會(huì)遇到因?yàn)镴avaScript事件冒泡而影響功能的實(shí)現(xiàn)情況,又或者事件冒泡對(duì)最終實(shí)現(xiàn)效果影響不大,可忽略。2010-01-01JS實(shí)現(xiàn)獲取word文檔內(nèi)容并輸出顯示到html頁(yè)面示例
這篇文章主要介紹了JS實(shí)現(xiàn)獲取word文檔內(nèi)容并輸出顯示到html頁(yè)面,結(jié)合實(shí)例形式分析了JavaScript使用ActiveXObject組建操作word文件的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-06-06JavaScript中從setTimeout與setInterval到AJAX異步
這篇文章主要介紹了JavaScript中從setTimeout與setInterval到AJAX異步,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02