如何?jQuery的Ajax檔案上傳,PHP如實檔案上傳. AJAX上傳檔案,PHP上傳檔案。

來源:互聯網
上載者:User
如何?jQuery的Ajax檔案上傳,PHP如實檔案上傳. AJAX上傳檔案,PHP上傳檔案。

在開始之前,我覺得是有必要把通WEB上傳檔案的原理簡單說一下的。
實際上,在這裡不管是PHP,JSP,還是ASP處理上傳的檔案,其實都是WEB早已把檔案上傳到伺服器了,我們只是運用上傳處理函數來處理上傳的檔案。
而處理函數一般都是用PHP,JSP,ASP等服務端語言來實現的。那麼如何通過WEB(HTTP協議來上傳檔案呢?)你需要類似於以下的HTML代碼:
test.html
<form action="do_file_upload.php" method="post" enctype="multipart/form-data">
<p>Pictures:
<input type="file" name="picture" />
<input type="submit" value="Send" />
</p>
</form>
注意:enctype="multipart/form-data",是必需的,它告訴FORM表這個是一檔案上傳類型,一旦這次請求成功後,檔案就被上傳到了伺服器的臨時檔案夾中,
至於到達目的地後,檔案將會被怎麼樣處理那就是PHP,JSP,ASP的事了。
(不過,你不要高興的太早,如果該檔案沒有被移動到其它地方也沒有被改名,則該檔案將在表單請求結束時被刪除。所以我們要寫一個處理上傳檔案的指令碼)
這裡我們用PHP來處理
do_file_upload.php
<?php
$error = ""; //上傳檔案出錯資訊
$msg = "";
$fileElementName = 'picture';
    $allowType = array(".jpg",".gif",".png"); //允許上傳的檔案類型
    $num      = strrpos($_FILES['picture']['name'] ,'.');  
$fileSuffixName    = substr($_FILES['picture']['name'],$num,8);//此數可變  
$fileSuffixName    = strtolower($fileSuffixName); //確定上傳檔案的類型
   
$upFilePath             = 'd:/'; //最終存放路徑

if(!empty($_FILES[$fileElementName]['error']))
{
   switch($_FILES[$fileElementName]['error'])
   {

    case '1':
     $error = '傳的檔案超過了 php.ini 中 upload_max_filesize 選項限制的值';
     break;
    case '2':
     $error = '上傳檔案的大小超過了 HTML 表單中 MAX_FILE_SIZE 選項指定的值';
     break;
    case '3':
     $error = '檔案只有部分被上傳';
     break;
    case '4':
     $error = '沒有檔案被上傳';
     break;

    case '6':
     $error = '找不到臨時檔案夾';
     break;
    case '7':
     $error = '檔案寫入失敗';
     break;
    default:
     $error = '未知錯誤';
   }
}elseif(empty($_FILES['fileToUpload']['tmp_name']) || $_FILES['fileToUpload']['tmp_name'] == 'none')
{
   $error = '沒有上傳檔案.';
}else if(!in_array($fileSuffixName,$allowType))
{
   $error = '不允許上傳的檔案類型';
}else{
  
$ok=@move_uploaded_file($_FILES['fileToUpload']['tmp_name'],$upFilePath);
   if($ok === FALSE){
    $error = '上傳失敗';
   }
}
?>


另註:關於$_FILES數組
此數組包含有所有上傳的檔案資訊,即記錄下了上傳檔案時的相關資訊。
以上範例中 $_FILES 數組的內容如下所示。我們假設檔案上傳欄位的名稱如上例所示,為 userfile。名稱可隨意命名。

$_FILES['userfile']['name']
用戶端機器檔案的原名稱。

$_FILES['userfile']['type']
檔案的 MIME 類型,如果瀏覽器提供此資訊的話。一個例子是“image/gif”。不過此 MIME 類型在 PHP 端並不檢查,因此不要想當然認為有這個值。

$_FILES['userfile']['size']
已上傳檔案的大小,單位為位元組。

$_FILES['userfile']['tmp_name']
檔案被上傳後在服務端儲存的臨時檔案名稱。

$_FILES['userfile']['error']
和該檔案上傳相關的錯誤碼。此項目是在 PHP 4.2.0 版本中增加的。

【AJAX檔案上傳】

其實就是實現無重新整理式的檔案上傳。可採用IFRAME檔案上傳原理。
實際上在用PHP上傳檔案時。。。只能用$_FILES形式,但是若我們只是單一的用JS方式取其ID,如<input id='img' type='file'>..document.getElementById('img').value或者jquery形式的$("#img")都是不能正真實際上傳的(但是還是有很多人這樣做,剛開始時我也是)。
可是功能上又要要求實現所謂的“非同步上傳”,怎麼辦呢??只能藉助於第三方的組件,或者自己寫一個(在網頁裡嵌入一個IFRAME)。但如果是考慮開發時間,那以用第三方的,這裡有一個不錯的jQuery的Ajax檔案上傳的組件,是“ajaxfileupload.js",其組件為:
http://www.phpletter.com/,下載完畢裡面有一個php的應用demo,很容易看懂的。
過程:
(1 )前端上檔案的代碼: test.php       

    <script type="text/javascript" src="jquery.js"></script>
    <script type="text/javascript" src="ajaxfileupload.js"></script>
    <script type="text/javascript">
       function ajaxFileUpload()
               {
                  $.ajaxFileUpload
                     (
                       {
                           
url:'doajaxfileupload.php',
//你處理上傳檔案的服務端
                            secureuri:false,
                            fileElementId:'img',
                            dataType: 'json',
                            success: function (data)
                                  {
                                    alert(data.file_infor);
                                  }
                               }
                         )

                       return false;
                 }
     </script>
相應的HTML為:
        <input id="img" type="file" size="45" name="img" class="input">
        <button class="button" id="buttonUpload" onclick="return ajaxFileUpload();">Upload</button>

這樣用戶端就完成了。
        
(2) 再伺服器端時   doajaxfileupload.php

   此處為了簡便的檢測是否真正的傳值過來了,你可以將它存起來了。
             $file_infor = var_export($_FILES,true);
             file_put_contents("d:file_infor.php".$file_infor);
   這樣你打來剛產生的file_infor.php檔案時,你又看到了熟悉的資訊了:
     array(
             'name'=>'lamp.jpg',
             'type'=>'image/pjpeg',
             'tmp_name'=>'c:\windows\temp\phpFA.tmp',
             'error'=>0,
             'size'=>3127
         )
當然,真正的處理類於這樣的:
  
<?php
     $upFilePath = "d:/";
    
$ok=@move_uploaded_file($_FILES['img']['tmp_name'],$upFilePath);
   if($ok === FALSE){
    echo json_encode('file_infor'=>'上傳失敗');
   }else{
    echo json_encode('file_infor'=>'上傳成功');
   }
   ?>   
另註:實際上,你可以在一個頁面裡嵌入一個IFRAME,然後在IFRAME使用原生的POST表單提交.JQUERY的這個外掛程式也是採用了這種方式。只不過它是動態產生的IFRAME 與表單

 

如有問題請看原貼:

原貼:http://hi.baidu.com/fc_lamp/blog/item/ca86edc6b508e9d5d10060ed.html

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.