欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-04-10 10:50:31
xmlhttprequest level 2 添加了一个新的接口——formdata。与普通的 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.<form>的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.没有<form>标签(有了也不错)

2.append()方法的第二个参数是文件对象,在html中已经通过loadfile方法的参数传过来

3.后端通过web.input获取文件的字段名,同前端append()方法的第一个参数

4.因为通过web.input获取的值都是字符串,如果除文件以外的键值对传过来是null,会自动转化为字符串'null'。这点处理的时候需要注意

以上所述是小编给大家介绍的jquery ajax使用formdata上传文件和其他数据后端web.py获取,希望对大家有所帮助