formData上传文件

Posted 苏二小姐

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了formData上传文件相关的知识,希望对你有一定的参考价值。

需要将选中的xml传到后台,通过xslt转换为html

html:


  <form id="uploadForm" enctype="multipart/form-data">
   <input type="file" name="testFile" value="选择文件">
   <input type="button" value="添加" id="btn">
  </form>


 

js:

<script type="text/javascript">
    var formData = new FormData($( "#uploadForm" )[0]);  
        $.ajax({  
             url: url ,  
             type: ‘POST‘,  
             data: formData,  
             async: false,  
             cache: false,  
             contentType: false,  
             processData: false,  
             success: function (data) {  
          ....
             },  
             error: function (returndata) {  
                 alert("出错了");  
             }  
        }); 
  });
 </script>

  

这里要注意几点:

  • processData设置为false。因为data值是FormData对象,不需要对数据做处理。
  • <form>标签添加enctype="multipart/form-data"属性。
  • cache设置为false,上传文件不需要缓存。
  • contentType设置为false。因为是由<form>表单构造的FormData对象,且已经声明了属性enctype="multipart/form-data",所以这里设置为false。

上传后,服务器端代码需要使用从查询参数名为file获取文件输入流对象,因为<input>中声明的是name="file"



以上是关于formData上传文件的主要内容,如果未能解决你的问题,请参考以下文章

在 Angular 5 中使用文件上传保存 FormData

使用formData上传文件,ajax上传

Spring文件下载与上传 FormData

未定义 FormData 时如何在 Web Workers 中上传文件

使用FormData,进行Ajax请求并上传文件

如何检查浏览器是不是支持 HTML5 文件上传(FormData 对象)?