PHP實現(xiàn)本地圖片上傳和驗證功能
今天研究了一下PHP的FILES函數(shù),使用PHP實現(xiàn)本地圖片的上傳,驗證文件是否為圖片,并將圖片保存在指定目錄下,實現(xiàn)游覽圖片的功能,感覺還是很好玩的,一共有兩個PHP頁面,一個作為前臺的上傳和圖片展示,另一個用來處理保存圖片,代碼里做了很詳細的注釋,并將FILES函數(shù)的語法,error報錯類型寫了出來,還有一些注意事項。
FILES函數(shù)
1、$_FILES[‘myFile'][‘name'] 客戶端文件的原名稱
2、$_FILES[‘myFile'][‘type'] 文件的 MIME類型,需要瀏覽器提供該信息的支持,例如”image/gif”
3、$_FILES[‘myFile'][‘size'] 已上傳文件的大小,單位為字節(jié)
4、$_FILES[‘myFile'][‘tmp_name'] 文件被上傳后在服務端儲存的臨時文件名,一般是系統(tǒng)默認,可以在php.ini的upload_tmp_dir指定
關于FILES中error報錯類型及其注意:
過濾錯誤號
0: 沒有錯誤發(fā)生,文件上傳成功
1: 上傳的文件超過了 php.ini 中 upload_max_filesize選項限制的值
2: 上傳文件的大小超過了 HTML 表單中 MAX_FILE_SIZE 選項指定的值
3: 文件只有部分被上傳
4: 沒有文件被上傳
5: 上傳文件大小為0
注意:
1、文件被上傳結束后,默認地被存儲在了臨時目錄中,這時必須將它從臨時目錄中刪除或移動到其它地方,如果沒有,則會被刪除。也就是不管是否上傳成功,腳本執(zhí)行完后臨時目錄里的文件肯定會被刪除。所以在刪除之前要用PHP的copy() 函數(shù)將它復制到其它位置,此時,才算完成了上傳文件過程。
2、在 PHP 4.1.0 版本以前該數(shù)組的名稱為$HTTP_POST_FILES,它并不像_FILES 一樣是自動全局變量。PHP 3 不支持HTTP_POST_FILES數(shù)組。
3、用form上傳文件時,一定要加上屬性內容enctype=”multipart/form-data”,否則用$_FILES[filename]獲取文件信息時會報異常。
以下是代碼
index.php
<?php header("Content-Type:text/html;charset=utf-8"); ?> <title>PHP實現(xià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>序號</th> <th>圖片</th> <th>添加時間</th> <th>操作</th> </tr> <?php //1 打開目錄 $dir=opendir("./uploads"); //2 遍歷目錄,輸出里面的圖片 $i=0; while($f=readdir($dir)){ $i++; //讀取目錄中的文件,模擬數(shù)據庫操作 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 關閉目錄 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 "上傳文件錯誤!"; echo '<meta http-equiv="refresh" content="3;url=index.php">'; //自動跳轉回index文件 }else{ //開始獲取上傳文件的信息 $file=$_FILES['pic']; //var_dump($file);打印文件里的全部信息 //name:上傳文件名 //type:上傳文件的類型 //tmp_name:上傳成功后的臨時文件 //size:上傳文件的大小 //error:上傳文件的錯誤信息 $uploaddir="./uploads/"; //選擇要上傳的文件存放目錄 //$uploadfile=$uploaddir.basename($file['name']);//獲得上傳文件的名稱 //解析文件的名字 $fileinfo=pathinfo($file['name']); // echo $fileinfo['extension']; 獲取文件的類型 do{ $newfile=date("YmdHis").rand(1000,9999).".".$fileinfo['extension'];//更改文件的名字,獲取一個新的名字 }while(file_exists($uploaddir.$newfile)); //上傳文件的類型限制 if (!(($file['type'] == "image/gif")||($file['type'] == "image/jpeg")||($file['type'] == "image/pjpeg"))){ die("文件類型錯誤!"); echo '<meta http-equiv="refresh" content="3;url=index.php">'; } //上傳文件的大小限制 if($file['size'] > 2*1024*1024){ die("上傳文件超過2MB!"); echo '<meta http-equiv="refresh" content="3;url=index.php">'; } //開始上傳文件 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">';//自動跳轉回index文件 } else { echo "上傳失敗,請稍等!"; echo '<meta http-equiv="refresh" content="3;url=index.php">'; //自動跳轉回index文件 } } } ?>
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
JS實現(xiàn)獲取word文檔內容并輸出顯示到html頁面示例
這篇文章主要介紹了JS實現(xiàn)獲取word文檔內容并輸出顯示到html頁面,結合實例形式分析了JavaScript使用ActiveXObject組建操作word文件的相關實現(xiàn)技巧,需要的朋友可以參考下2018-06-06JavaScript中從setTimeout與setInterval到AJAX異步
這篇文章主要介紹了JavaScript中從setTimeout與setInterval到AJAX異步,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-02-02