程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> php iframe實現無刷新文件上傳(無需ajax)

php iframe實現無刷新文件上傳(無需ajax)

編輯:關於PHP編程

本文章來介紹一下關於文件上傳的方法,一個利用了php iframe來實現上傳這個也是無刷新的哦,有需要的同學可以參考一下下哈。

首先ajax不能上傳文件,這誤導了我有段時間,今晚睡不著就照著說明做了個無刷新上傳文件

其實原理很簡單

 代碼如下 復制代碼

<form enctype="multipart/form-data" method="POST" target="upload" action="http://localhost/class.upload.php" >
          <input type="file" name="uploadfile" />
          <input type="submit" />
</form>
<iframe name="upload" style="display:none"></iframe>


和一般的<form>標簽相比多了一個target屬性罷了,用於指定標簽頁在哪裡打開以及提交數據。

如果沒有設置該屬性,就會像平常一樣在本頁重定向打開action中的url。

而如果設置為iframe的name值,即"upload"的話,就會在該iframe內打開,因為CSS設置為隱藏,因而不會有任何動靜。若將display:none去掉,還會看到服務器的返回信息。

另外貼一下自己組織的類。

 代碼如下 復制代碼

class upload
{
   public $_file;

   public function __construct( $name =null)
   {
       if(is_null($name) || !isset($_FILES[$name]))
            $name = key($_FILES);
           
       if(!isset($_FILES[$name]))
           throw new Exception("並沒有文件上傳");
          
       $this->_file  = $_FILES[$name];
      
       if(!is_uploaded_file($this->_file['tmp_name']))
            throw new Exception("異常情況");
       if($this->_file['error'] !== 0)
            throw new Exception("錯誤代碼:".$this->_file['error']);    
   }
   public function moveTo( $new_dir)
   {
       $real_dir = $this->checkDir($new_dir);
       return move_uploaded_file($this->_file['tmp_name'], $real_dir.'/'.$this->_file['name']);
   }
   private function checkDir($dir)
   {
       $real_dir = realpath($dir);
       if($real_dir === false)
           throw new Exception("給定目錄{$dir}不存在");
       if(!is_writable($real_dir))
           throw new Exception("給定目錄{$dir}不可寫");
       return $real_dir;
   }

}

調用示例:

 代碼如下 復制代碼

$inputName =  'uploadfile';
 // 即<input type=“file" name="uploadfile" /> 中的name值,不填也行
$upload = new upload($inputName);
$new_dir = "/www";  // 將文件移動到的路徑
$upload->moveTo($new_dir);


  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved