色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

jQuery Ajax文件上傳(php)

如何實(shí)現(xiàn)jQuery的Ajax文件上傳,php如實(shí)文件上傳.
AJAX上傳文件,php上傳文件。

php文件上傳】

在開(kāi)始之前,我覺(jué)得是有必要把通WEB上傳文件的原理簡(jiǎn)單說(shuō)一下的。
實(shí)際上,在這里不管是php,JSP,還是ASP處理上傳的文件,其實(shí)都是WEB早已把文件上傳到服務(wù)器了,我們只是運(yùn)用上傳處理函數(shù)來(lái)處理上傳的文件。
而處理函數(shù)一般都是用php,JSP,ASP等服務(wù)端語(yǔ)言來(lái)實(shí)現(xiàn)的。那么如何通過(guò)WEB(HTTP協(xié)議來(lái)上傳文件呢?)你需要類(lèi)似于以下的HTML代碼:
test.html

復(fù)制代碼 代碼如下:
<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表這個(gè)是一文件上傳類(lèi)型,一旦這次請(qǐng)求成功后,文件就被上傳到了服務(wù)器的臨時(shí)文件夾中,
至于到達(dá)目的地后,文件將會(huì)被怎么樣處理那就是php,JSP,ASP的事了。
(不過(guò),你不要高興的太早,如果該文件沒(méi)有被移動(dòng)到其它地方也沒(méi)有被改名,則該文件將在表單請(qǐng)求結(jié)束時(shí)被刪除。所以我們要寫(xiě)一個(gè)處理上傳文件的腳本)
這里我們用php來(lái)處理
do_file_upload.php

復(fù)制代碼 代碼如下:
<?php
$error = ""; //上傳文件出錯(cuò)信息
$msg = "";
$fileElementName = 'picture';
    $allowType = array(".jpg",".gif",".png"); //允許上傳的文件類(lèi)型
    $num      = strrpos($_FILES['picture']['name'] ,'.'); 
$fileSuffixName    = substr($_FILES['picture']['name'],$num,8);//此數(shù)可變 
$fileSuffixName    = strtolower($fileSuffixName); //確定上傳文件的類(lèi)型

$upFilePath             = 'd:/'; //最終存放路徑

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

    case '1':
     $error = '傳的文件超過(guò)了 php.ini 中 upload_max_filesize 選項(xiàng)限制的值';
     break;
    case '2':
     $error = '上傳文件的大小超過(guò)了 HTML 表單中 MAX_FILE_SIZE 選項(xiàng)指定的值';
     break;
    case '3':
     $error = '文件只有部分被上傳';
     break;
    case '4':
     $error = '沒(méi)有文件被上傳';
     break;

    case '6':
     $error = '找不到臨時(shí)文件夾';
     break;
    case '7':
     $error = '文件寫(xiě)入失敗';
     break;
    default:
     $error = '未知錯(cuò)誤';
   }
}elseif(empty($_FILES['fileToUpload']['tmp_name']) || $_FILES['fileToUpload']['tmp_name'] == 'none')
{
   $error = '沒(méi)有上傳文件.';
}else if(!in_array($fileSuffixName,$allowType))
{
   $error = '不允許上傳的文件類(lèi)型';
}else{
  );
   if($ok === FALSE){
    $error = '上傳失敗';
   }
}
?>

另注:關(guān)于$_FILES數(shù)組

此數(shù)組包含有所有上傳的文件信息,即記錄下了上傳文件時(shí)的相關(guān)信息。
以上范例中 $_FILES 數(shù)組的內(nèi)容如下所示。我們假設(shè)文件上傳字段的名稱(chēng)如上例所示,為 userfile。名稱(chēng)可隨意命名。

$_FILES['userfile']['name']
客戶(hù)端機(jī)器文件的原名稱(chēng)。

$_FILES['userfile']['type']
文件的 MIME 類(lèi)型,如果瀏覽器提供此信息的話(huà)。一個(gè)例子是“image/gif”。不過(guò)此 MIME 類(lèi)型在 php 端并不檢查,因此不要想當(dāng)然認(rèn)為有這個(gè)值。

$_FILES['userfile']['size']
已上傳文件的大小,單位為字節(jié)。

$_FILES['userfile']['tmp_name']
文件被上傳后在服務(wù)端儲(chǔ)存的臨時(shí)文件名。

$_FILES['userfile']['error']
和該文件上傳相關(guān)的錯(cuò)誤代碼。此項(xiàng)目是在 php 4.2.0 版本中增加的。

【AJAX文件上傳】

其實(shí)就是實(shí)現(xiàn)無(wú)刷新式的文件上傳。可采用IFRAME文件上傳原理。
實(shí)際上在用php上傳文件時(shí)。。。只能用$_FILES形式,但是若我們只是單一的用JS方式取其ID,如<input id='img' type='file'>..document.getElementById('img').value或者jquery形式的$("#img")都是不能正真實(shí)際上傳的(但是還是有很多人這樣做,剛開(kāi)始時(shí)我也是)。
可是功能上又要要求實(shí)現(xiàn)所謂的“異步上傳”,怎么辦呢??只能借助于第三方的組件,或者自己寫(xiě)一個(gè)(在網(wǎng)頁(yè)里嵌入一個(gè)IFRAME)。但如果是考慮開(kāi)發(fā)時(shí)間,那以用第三方的,這里有一個(gè)不錯(cuò)的jQuery的Ajax文件上傳的組件,是“ajaxfileupload.js",其組件下載地址為:http://www.phpletter.com/,下載完畢里面有一個(gè)php應(yīng)用demo,很容易看懂的。
過(guò)程:
(1 )前端上文件的代碼: test.php      
復(fù)制代碼 代碼如下:
    <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', //你處理上傳文件的服務(wù)端
                            secureuri:false,
                            fileElementId:'img',
                            dataType: 'json',
                            success: function (data)
                                  {
                                    alert(data.file_infor);
                                  }
                               }
                         )

                       return false;
                 }
     </script>

相應(yīng)的HTML為:

復(fù)制代碼 代碼如下:
        <input id="img" type="file" size="45" name="img" class="input">
        <button class="button" id="buttonUpload" onclick="return ajaxFileUpload();">Upload</button>

這樣客戶(hù)端就完成了。

(2) 再服務(wù)器端時(shí)   doajaxfileupload.php

   此處為了簡(jiǎn)便的檢測(cè)是否真正的傳值過(guò)來(lái)了,你可以將它存起來(lái)了。
             $file_infor = var_export($_FILES,true);
             file_put_contents("d:file_infor.php".$file_infor);
   這樣你打來(lái)剛生成的file_infor.php文件時(shí),你又看到了熟悉的信息了:
復(fù)制代碼 代碼如下:
     array(
             'name'=>'lamp.jpg',
             'type'=>'image/pjpeg',
             'tmp_name'=>'c:/windows/temp/phpFA.tmp',
             'error'=>0,
             'size'=>3127
         )


當(dāng)然,真正的處理類(lèi)于這樣的:

復(fù)制代碼 代碼如下:
   <?php
     $upFilePath = "d:/";
     );
   if($ok === FALSE){
    echo json_encode('file_infor'=>'上傳失敗');
   }else{
    echo json_encode('file_infor'=>'上傳成功');
   }
   ?>   


另注:實(shí)際上,你可以在一個(gè)頁(yè)面里嵌入一個(gè)IFRAME,然后在IFRAME使用原生的POST表單提交.JQUERY的這個(gè)插件也是采用了這種方式。只不過(guò)它是動(dòng)態(tài)生成的IFRAME 與表單

原文: http://fc-lamp.blog.163.com/blog/static/1745666872009519310153/

JavaScript技術(shù)jQuery Ajax文件上傳(php),轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 水富县| 苍梧县| 公安县| 湘潭县| 宁强县| 太和县| 留坝县| 阿鲁科尔沁旗| 喀喇沁旗| 温宿县| 博客| 陆丰市| 沙河市| 资阳市| 略阳县| 沙田区| 河池市| 望谟县| 吐鲁番市| 乌拉特前旗| 靖州| 崇阳县| 保康县| 宜君县| 太仆寺旗| 宝山区| 泰兴市| 彰化市| 正阳县| 开鲁县| 安顺市| 葫芦岛市| 改则县| 德庆县| 乌鲁木齐县| 山西省| 丹凤县| 双柏县| 江川县| 拜泉县| 青河县|