php+ajax(jquery)的文件異步上傳


    這里我用到了ajaxFileUpload插件。

    基本用法:

 

 1 $.ajaxFileUpload({
 2 
 3         url:'',//單引號間填寫上傳處理文件的路徑。
 4 
 5         fileElementId:'',//單引號間填寫上傳文件的id。
 6 
 7         secureuri:'',//單引號間填寫的內容表示是否安全提交,默認填寫false。
 8 
 9         dataType:'',//單引號間填寫經服務器處理之后返回的數據類型,這里有xml,script,json,html,text。
10 
11         data:'',//單引號間填寫填寫除文件信息外的其它信息,用json數據格式。
12 
13         type:'',//單引號間填寫提交信息是的方法,常用的有post和get。
14 
15         success:function(data,status){},//參數data為后台處理文件返回的數據,status是返回的狀態,這里有error、success、timeout。{}之間是對返回結果的處理。
16 
17         error:function(data,status,e){}//data和error參數同上,e是異常信息。
18 
19     })

 

    例子:

    首先是fileupload.html

<html>
<head>
<title></title>
<meta http-equiv="Content-Type" content="text/html; charset=utf8">
<script type="text/javascript" src="../js/jquery.js"></script> 
<script type="text/javascript" src="../js/jquery.min.js"></script> 
<script type="text/javascript" src="../js/ajaxfileupload.js"></script>
<script type="text/javascript" src="../js/upload.js" charset="utf-8"></script>
</head>

<body>

<form action="" method="post" enctype="multipart/form-data" name="form1" id="myform">
     <input type="area" name="desmsg" id="desmsg" />
     <input type="file" name="filemsg" id="filemsg" />
     <input type="button" name="Submit" value="上 傳"  onclick="ajaxImgUpload()" />

</form>
</html>

 

    然后upload.js

function ajaxImgUpload(){
             $.ajaxFileUpload
                     (
                       {
                            url:'upfile.php', //你處理上傳文件的后台文件
                            type:'POST',
                            secureuri:false,
                            fileElementId:'filemsg',
                            dataType: 'json',
                            data:{describe:$("#desmsg").val()},
                            success: function (data,status)
                            {

                                //對返回結果的處理程序

                            },
                            error:function(data,status,e){

                                //對返回結果的處理程序

                            }

                        }

                      )
}

 

    最后是upfile.php

<?php

$myfile=$_FILES["filemsg"];
$describe=$_POST["describe"];


$fileTypeArray=array(
'application/vnd.ms-excel',
'text/plain',
'application/msword',
'application/zip',
'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
'application/vnd.openxmlformats-officedocument.wordprocessingml.template',
'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
'application/octet-stream'
);
$filename=myfile["name"];
$filetype=myfile["type"];
$filesize=myfile["size"];
$fileerror=myfile["error"];
if(in_array($filetype,$fileTypeArray)){
//限制大小
if($filesize<1024*1024*1024){
if($fileerror>0){
echo json_encode(myfile);
}else{
if(file_exists(iconv("UTF-8", "gb2312","../file/".$filename))){//防止中文亂碼

myfile["myallowerror"]=$filename."已經存在!無需上傳";
$url="../file/".$filename;
myfile["url"]=$url;
echo json_encode(myfile);

}else{
move_uploaded_file(myfile["tmp_name"],iconv("UTF-8", "gb2312","../file/".$filename));
$url="../file/".$filename;

echo json_encode(myfile);
}
}
}
}else{
myfile["myerror"]="不符合的文件類型";
echo json_encode(myfile);
}

 

 

    


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM