文件 jq 傳到后台


 

XMLHttpRequest Level 2 添加了一個新的接口——FormData。與普通的 Ajax 相比,使用 FormData 的最大優點就是我們可以異步上傳二進制文件。

jQuery 2.0+的版本支持FormData

方法一:使用<form>表單初始化FormData對象方式上傳文件

•前端(JQuery):

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<form enctype= "multipart/form-data" >
   <input type= "file" name= "myfile" onchange= "loadFile(this.files[0])" >
</form>
<script>
   function loadFile(file){
     var formdata = new FormData($$( 'form' )[0]);
     $.ajax({
       url: 'jobs/add' ,
       type: 'POST' ,
       datatype: 'json' ,
       data: formdata,
       cache: false ,
       traditional: true ,
       contentType: false ,
       processData: false ,
       success: function (data) {},
       error: function () {}
     });
   }
</script>

•后台(web.py):

?
1
2
3
4
5
6
class Add:
   def POST(self):
     i = web.input(myfile={})
     print(i[ 'myfile' ].filename) #文件名
     print(i[ 'myfile' ].value) #文件內容
     print(i[ 'myfile' ].file.read()) #文件內容

 注意:

1.<form>的enctype屬性需要設置為“multipart/form-data”

2.$.ajax中processData、contentType和cache需要設置為false

3.后端通過web.input獲取文件的字段名,同前端指定的input標簽的name屬性

方法二√:不用<form>,使用FormData對象添加字段方式上傳文件

有時,我們並不想用

標簽,而且通過ajax傳給后端的並不只有文件,可能還有其他的鍵值對,這時就可以用這個方法

•前端(JQuery):

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<input type= "file" onchange= "loadFile(this.files[0])" />
function loadFile(file){
   container.fd = new FormData();
   container.fd.append( 'myfile' ,file);
   container.fd.append( 'otherkey' ,othervalue);
   $.ajax({
     url: 'jobs/add' ,
     type: 'POST' ,
     datatype: 'json' ,
     data: fd,
     cache: false ,
     traditional: true ,
     contentType: false ,
     processData: false ,
     success: function (data) {},
     error: function () {}
   });
}

•后台(web.py):

?
1
2
3
4
5
6
class Add:
   def POST(self):
     i = web.input(myfile={}, otherkey= '' )
     print(i[ 'myfile' ].filename) #文件名
     print(i[ 'myfile' ].value) #文件內容
     print(i[ 'myfile' ].file.read()) #文件內容

前台2:

 <input type="file" id="fileContent" onchange="file(this.files[0])" name="myfile"/>

    ////文件傳到后台的方法
        function file(f)
        {
            debugger;
            var formData = new FormData();
            var name = $("input").val();
            formData.append("file", $("#fileContent")[0].files[0]);
            formData.append("name", f.name);
            $.ajax({
                url: 'TestHandler.ashx',
                type: 'post',
                data: formData,
                datatype:'JSON',
                fileElementId: 'fileContent',
                // 告訴jQuery不要去處理發送的數據
                processData: false,
                // 告訴jQuery不要去設置Content-Type請求頭
                contentType: false,
                cache: false,
                traditional: true,
                success: function (data) {
                    $('#img').attr('src', data);
                }
            });
        }

  

后台2 :

HttpFileCollection files =context.Request.Files;
if (files != null && files.Count > 0)
{
////image 傳的文件流
Image i = Image.FromStream(files[0].InputStream);
byte[] re = new byte[files[0].ContentLength];
files[0].InputStream.Read(re, 0,files[0].ContentLength);


string name=files[0].FileName;
string path = @"C:\Users\duxiaoqin\Desktop\" + name;
i.Save(path);
context.Response.Write(path);
context.Response.End();
}

  

注意:

1.沒有<form>標簽(有了也不錯)

2.append()方法的第二個參數是文件對象,在html中已經通過loadFile方法的參數傳過來

3.后端通過web.input獲取文件的字段名,同前端append()方法的第一個參數

4.因為通過web.input獲取的值都是字符串,如果除文件以外的鍵值對傳過來是null,會自動轉化為字符串'null'。這點處理的時候需要注意

以上所述是小編給大家介紹的jQuery Ajax使用FormData上傳文件和其他數據后端web.py獲取,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的




免責聲明!

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



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