jQuery Ajax使用FormData上傳文件和其餘數據,後端web.py獲取

參考博文:
  Web 前沿——HTML5 Form Data 對象的使用
  經過jQuery Ajax使用FormData對象上傳文件


XMLHttpRequest Level 2 添加了一個新的接口——FormData。與普通的 Ajax 相比,使用 FormData 的最大優勢就是咱們能夠異步上傳二進制文件。
jQuery 2.0+的版本支持FormDatahtml

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

  • 前端(JQuery):
<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):
class Add:
    def POST(self):
        i = web.input(myfile={})
        print(i['myfile'].filename) #文件名
        print(i['myfile'].value) #文件內容
        print(i['myfile'].file.read()) #文件內容



注意:html5

  1. <form>的enctype屬性須要設置爲「multipart/form-data」
  2. $.ajax中processData、contentType和cache須要設置爲false
  3. 後端經過web.input獲取文件的字段名,同前端指定的input標籤的name屬性


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

有時,咱們並不想用ajax

標籤,並且經過ajax傳給後端的並不僅有文件,可能還有其餘的鍵值對,這時就能夠用這個方法

  • 前端(JQuery):
<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):
class Add:
    def POST(self):
        i = web.input(myfile={}, otherkey='')
        print(i['myfile'].filename) #文件名
        print(i['myfile'].value) #文件內容
        print(i['myfile'].file.read()) #文件內容



注意:json

  1. 沒有<form>標籤(有了也不錯)
  2. append()方法的第二個參數是文件對象,在html中已經經過loadFile方法的參數傳過來
  3. 後端經過web.input獲取文件的字段名,同前端append()方法的第一個參數
  4. 由於經過web.input獲取的值都是字符串,若是除文件之外的鍵值對傳過來是null,會自動轉化爲字符串'null'。這點處理的時候須要注意
相關文章
相關標籤/搜索