php表單檔案iframe非同步上傳教程講解

來源:互聯網
上載者:User
這篇文章主要為大家詳細介紹了php表單檔案iframe非同步上傳執行個體,具有一定的參考價值,感興趣的小夥伴們可以參考一下

本文執行個體為大家分享了php表單檔案iframe非同步上傳的具體代碼,供大家參考,具體內容如下

1.表單中放置iframe元素;
2.檔案上傳控制項內容變化的時候觸發JS設定表單的action為處理檔案上傳的img_upload_process.php檔案,並且將表單的target設定為iframe,讓iframe去提交到伺服器進行檔案上傳;
3.img_upload_process.php中處理檔案上傳成功後,將上傳成功儲存的檔案路徑回傳給表單中隱藏欄位;
4.點擊表單提交按鈕的時,JS設定表單action為接收表單資料的form_process.php檔案,表單的target設定為_self。

表單:asyn_uplaod.html


<!DOCTYPE html><html><head><meta charset="UTF-8"><title>圖片非同步上傳</title></head><body><!-- application/x-www-form-urlencoded 預設編碼類別型 --><!-- multipart/form-data 多媒體傳輸協議 ,方法必須是post 既可以發送文本資料,也支援位元據上傳 --><form action="" method="post" enctype="multipart/form-data"> 使用者名稱: <input type="text" name="username" /><br />  上傳頭像: <input type="file" id="avator" name="avator" onchange="startUpload(this.form)" /> <iframe frameborder='0' width='0' height='0' name="uploadframe"></iframe>  <input type="hidden" id="save_path" name="save_path" /> <span id="loading"></span> <br />  <img width='100' height='100' id='uploaded_img' /> <br /> <input type="submit" name="submitted" value="提交" onclick="formSubmit(this.form)" /></form><script>function startUpload(formObj){  document.getElementById('loading').innerHTML = '上傳中...';   formObj.action = 'img_upload_process.php';   formObj.target = 'uploadframe';   formObj.submit(); }function formSubmit(formObj) { formObj.action = 'form_process.php';  formObj.target = '_self'; //清空檔案上傳內容,防止重複提交 var fileObj = document.getElementById('avator') ; // for IE, Opera, Safari, Chrome if (fileObj.outerHTML) {  fileObj.outerHTML = fileObj.outerHTML; } else { // FF(包括3.5)  fileObj.value = ""; } formObj.submit(); }</script></body></html>

處理檔案上傳:img_upload_process.php


<?phpinclude 'Upload.class.php';$file = $_FILES['avator'];$upload = new Upload();//上傳工具類對象if($save_path = $upload->up($file)){//上傳成功 echo <<<STR <script>   window.parent.document.getElementById('uploaded_img').src = "$save_path";  window.parent.document.getElementById('loading').innerHTML = '上傳成功';   window.parent.document.getElementById('save_path').value = "$save_path";  </script>STR;}else{ $error = $upload->error(); echo <<<STR <script>  window.parent.document.getElementById('uploaded_img').src = "";  window.parent.document.getElementById('loading').innerHTML = "上傳失敗: $error"; </script>STR;}

檔案上傳工具類:Upload.class.php


<?phpclass Upload{ private $path; //檔案上傳目錄 private $max_size; //上傳檔案大小限制 private $errno; //錯誤資訊號 private $mime = array('image/jpeg','image/png','image/gif');//允許上傳的檔案類型 /**  * 建構函式,  * @access public  * @param $path string 上傳的路徑  */ public function __construct($path = './' ){  $this->path = $path;  $this->max_size = 1000000; } /**  * 檔案上傳的方法,分目錄存放檔案  * @access public  * @param $file array 包含上傳檔案資訊的數組  * @return mixed 成功返回上傳的檔案名稱,失敗返回false  */ public function up($file){  //判斷檔案是否是通過 HTTP POST 上傳,防止惡意欺騙  /*  if (! is_uploaded_file($file['tmp_name'])) {   $this->errno = 5; //設定錯誤資訊號為5,表示非法上傳   return false;  }  */  //判斷是否從瀏覽器端成功上傳到伺服器端  if ($file['error'] == 0) {   # 上傳到臨時檔案夾成功,對臨時檔案進行處理   //上傳類型判斷   if (!in_array($file['type'], $this->mime)) {    # 類型不對    $this->errno = -1;     return false;   }   //判斷檔案大小   if ($file['size'] > $this->max_size) {    # 大小超出設定檔的中的上傳限制    $this->errno = -2;    return false;   }   //擷取存放上傳檔案的目錄   $sub_path = date('Ymd').'/';   if (!is_dir($this->path . $sub_path)) {    # 不存在該目錄,建立之    mkdir($this->path . $sub_path);   }   //檔案重新命名,由當前日期 + 隨機數 + 尾碼名   $file_name = date('YmdHis').uniqid().strrchr($file['name'], '.');   //準備就緒了,開始上傳   if (move_uploaded_file($file['tmp_name'], $this->path . $sub_path . $file_name)) {    # 移動成功    return $sub_path . $file_name;   } else {    # 移動失敗    $this->errno = -3;    return false;   }  } else {   # 上傳到臨時檔案夾失敗,根據其錯誤號碼設定錯誤號碼   $this->errno = $file['error'];   return false;  } } /**  * 多檔案上傳方法  * @access public  * @param $file array 包含上傳檔案資訊的數組,是一個二維數組  * @return array 成功返回上傳的檔案名稱構成的數組, ?如果有失敗的則不太好處理了  */ public function multiUp($files){  //在多檔案上傳時,上傳檔案資訊 又是一個多維陣列,如$_FILES['userfile']['name'][0],$_FILES['userfile']['name'][1]  //我們只需要遍曆該數組,得到每個上傳檔案的資訊,依次調用up方法即可  foreach ($files['name'] as $key => $value) {   # code...   $file['name'] = $files['name'][$key];   $file['type'] = $files['type'][$key];   $file['tmp_name'] = $files['tmp_name'][$key];   $file['error'] = $files['error'][$key];   $file['size'] = $files['size'][$key];   //調用up方法,完成上傳   $filename[] = $this->up($file);  }  return $filename; } /**  * 擷取錯誤資訊,根據錯誤號碼擷取相應的錯誤提示  * @access public  * @return string 返回錯誤資訊  */ public function error(){  switch ($this->errno) {   case -1:    return '請檢查你的檔案類型,目前支援的類型有'.implode(',', $this->mime);    break;   case -2:    return '檔案超出系統規定的大小,最大不能超過'. $this->max_size;    break;   case -3:    return '檔案移動失敗';    break;   case 1:    return '上傳的檔案超過了 php.ini 中 upload_max_filesize 選項限制的值,其大小為'.ini_get('upload_max_filesize');    break;   case 2:    return '上傳檔案的大小超過了 HTML 表單中 MAX_FILE_SIZE 選項指定的值,其大小為' . $_POST['MAX_FILE_SIZE'];    break;   case 3:    return '檔案只有部分被上傳';    break;   case 4:    return '沒有檔案被上傳';    break;   case 5:    return '非法上傳';    break;   case 6:    return '找不到臨時檔案夾';    break;   case 7:    return '檔案寫入臨時檔案夾失敗';    break;   default:    return '未知錯誤,靈異事件';    break;  } }}

處理表單提交:form_process.php


<?phpvar_dump($_REQUEST);var_dump($_FILES);

點擊表單提交按鈕結果:

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.