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

发布时间 - 2026-01-11 01:49:33    点击率:

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获取,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!


# jquery  # ajax  # formdata  # 上传文件和数据  # Vue+axios使用FormData方式向后端发送数据  # 后端要求formdata传参前端该怎么处理详解  # 后端  # 上传文件  # 设置为  # 小编  # 键值  # 都是  # 字段名  # 第一个  # 可以用  # 其他的  # 我们可以  # 第二个  # 给大家  # 也不错  # 转化为  # 表单  # 想用  # 所述  # 需要注意  # 给我留言 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 东莞市网站制作公司有哪些,东莞找工作用什么网站好?  如何快速搭建高效可靠的建站解决方案?  JS去除重复并统计数量的实现方法  Javascript中的事件循环是如何工作的_如何利用Javascript事件循环优化异步代码?  浅谈Javascript中的Label语句  如何快速启动建站代理加盟业务?  Laravel怎么上传文件_Laravel图片上传及存储配置  如何利用DOS批处理实现定时关机操作详解  如何在阿里云完成域名注册与建站?  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  网站图片在线制作软件,怎么在图片上做链接?  Laravel如何配置和使用队列处理异步任务_Laravel队列驱动与任务分发实例  成都品牌网站制作公司,成都营业执照年报网上怎么办理?  动图在线制作网站有哪些,滑动动图图集怎么做?  千库网官网入口推荐 千库网设计创意平台入口  laravel服务容器和依赖注入怎么理解_laravel服务容器与依赖注入解析  网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?  网站建设要注意的标准 促进网站用户好感度!  Laravel如何自定义分页视图?(Pagination示例)  Laravel如何构建RESTful API_Laravel标准化API接口开发指南  C++时间戳转换成日期时间的步骤和示例代码  北京企业网站设计制作公司,北京铁路集团官方网站?  Laravel中间件起什么作用_Laravel Middleware请求生命周期与自定义详解  Python结构化数据采集_字段抽取解析【教程】  DeepSeek是免费使用的吗 DeepSeek收费模式与Pro版本功能详解  绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信  如何基于PHP生成高效IDC网络公司建站源码?  网站制作大概多少钱一个,做一个平台网站大概多少钱?  Laravel Blade模板引擎语法_Laravel Blade布局继承用法  如何在 React 中条件性地遍历数组并渲染元素  如何用好域名打造高点击率的自主建站?  网站页面设计需要考虑到这些问题  高防服务器如何保障网站安全无虞?  PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】  如何在万网ECS上快速搭建专属网站?  Edge浏览器如何截图和滚动截图_微软Edge网页捕获功能使用教程【技巧】  如何为不同团队 ID 动态生成多个“认领值班”按钮  Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲  大学网站设计制作软件有哪些,如何将网站制作成自己app?  在Oracle关闭情况下如何修改spfile的参数  Laravel怎么清理缓存_Laravel optimize clear命令详解  laravel怎么实现图片的压缩和裁剪_laravel图片压缩与裁剪方法  Laravel DB事务怎么使用_Laravel数据库事务回滚操作  Laravel模型关联查询教程_Laravel Eloquent一对多关联写法  如何挑选高效建站主机与优质域名?  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  制作企业网站建设方案,怎样建设一个公司网站?  香港服务器网站推广:SEO优化与外贸独立站搭建策略  如何在景安云服务器上绑定域名并配置虚拟主机?  Android okhttputils现在进度显示实例代码