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獲取,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的
