jQuery Ajax使用FormData上传文件和其他数据,后端web.py获取

参考博文:

  Web 前沿——HTML5 Form Data 对象的使用

  通过jQuery Ajax使用FormData对象上传文件



XMLHttpRequest Level 2 添加了一个新的接口——FormData。与普通的 Ajax 相比,使用 FormData 的最大优点就是我们可以异步上传二进制文件。

jQuery 2.0+的版本支持FormData

方法一:使用<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()) #文件内容

注意:
1. ``的enctype属性需要设置为“multipart/form-data”
2. $.ajax中processData、contentType和cache需要设置为false
3. 后端通过web.input获取文件的字段名,同前端指定的input标签的name属性

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

有时,我们并不想用标签,而且通过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()) #文件内容

注意:
1. 没有``标签(有了也不错)
2. `append()`方法的第二个参数是文件对象,在html中已经通过loadFile方法的参数传过来
3. 后端通过web.input获取文件的字段名,同前端`append()`方法的第一个参数
4. 因为通过web.input获取的值都是字符串,如果除文件以外的键值对传过来是null,会自动转化为字符串'null'。这点处理的时候需要注意

上一篇:帮谷歌推广Webp图片格式之:Webp的格式转换


下一篇:在windows上搭建react-native的android环境