欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP實現(xiàn)本地圖片上傳和驗證功能

 更新時間:2017年02月27日 12:00:57   作者:rain_web  
這篇文章主要為大家詳細介紹了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">&nbsp;</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文件
    }
   }

  }
 ?>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • layui 富文本編輯器和textarea值的相互傳遞方法

    layui 富文本編輯器和textarea值的相互傳遞方法

    今天小編就為大家分享一篇layui 富文本編輯器和textarea值的相互傳遞方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • Bootstrap項目實戰(zhàn)之首頁內容介紹(全)

    Bootstrap項目實戰(zhàn)之首頁內容介紹(全)

    本文分為兩部分介紹Bootstrap首頁內容介紹的實現(xiàn)代碼,感興趣的小伙伴們可以參考一下
    2016-04-04
  • 深入探究使JavaScript動畫流暢的一些方法

    深入探究使JavaScript動畫流暢的一些方法

    這篇文章主要介紹了使JavaScript動畫流暢的一些方法,包括與CSS動畫效果的一些對比,需要的朋友可以參考下
    2015-06-06
  • JavaScript設計模式組合設計模式案例

    JavaScript設計模式組合設計模式案例

    這篇文章主要介紹了JavaScript設計模式組合設計模式案例,組合設計模式是用于將多個部分通過組合的方式行成一個整體,更多相關內容需要的小伙伴可以參考一下
    2022-06-06
  • Js檢查變量類型的代碼()

    Js檢查變量類型的代碼()

    本文章為你提供一款js 返回變量的類型代碼哦,如果你不懂得如何獲取js變量的類型的話,看看我們下面的代碼你就知道如何獲取js變量的代碼哦。
    2010-07-07
  • JavaScript 事件冒泡應用實例分析

    JavaScript 事件冒泡應用實例分析

    在一些傳統(tǒng)的小型WEB應用開發(fā)過程中,JavaScript通常只是拿來做表單驗證而以,所以你很少會遇到因為JavaScript事件冒泡而影響功能的實現(xiàn)情況,又或者事件冒泡對最終實現(xiàn)效果影響不大,可忽略。
    2010-01-01
  • web打印小結

    web打印小結

    本文主要介紹了一款比較強大的web打印工具lodop實現(xiàn)將winform客戶端的打印,移到網頁上由客戶自行打印,打印要求是根據一定的格式實現(xiàn)套打的過程與方法。具有一定的參考價值,下面跟著小編一起來看下吧
    2017-01-01
  • JS實現(xiàn)獲取word文檔內容并輸出顯示到html頁面示例

    JS實現(xiàn)獲取word文檔內容并輸出顯示到html頁面示例

    這篇文章主要介紹了JS實現(xiàn)獲取word文檔內容并輸出顯示到html頁面,結合實例形式分析了JavaScript使用ActiveXObject組建操作word文件的相關實現(xiàn)技巧,需要的朋友可以參考下
    2018-06-06
  • js改變透明度實現(xiàn)輪播圖的算法

    js改變透明度實現(xiàn)輪播圖的算法

    這篇文章主要為大家詳細介紹了js改變透明度實現(xiàn)輪播圖的算法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-08-08
  • JavaScript中從setTimeout與setInterval到AJAX異步

    JavaScript中從setTimeout與setInterval到AJAX異步

    這篇文章主要介紹了JavaScript中從setTimeout與setInterval到AJAX異步,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-02-02

最新評論