ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、视频、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
## 场景一 提交一般参数 ~~~ <form id= "uploadForm" action= "http://localhost:8080/cfJAX_RS/rest/file/upload" method= "post" enctype ="multipart/form-data"> <h1 >测试通过Rest接口上传文件 </h1> <p >指定文件名: <input type ="text" name="filename" /></p> <p >上传文件: <input type ="file" name="file" /></p> <p >关键字1: <input type ="text" name="keyword" /></p> <p >关键字2: <input type ="text" name="keyword" /></p> <p >关键字3: <input type ="text" name="keyword" /></p> <input type ="submit" value="上传"/> </form> <script type="text/javascript"> $.ajax({ url : "http://youractionurl", type : "POST", data : $( '#uploadForm').serialize(), success : function(data) { $( '#serverResponse').html(data); }, error : function(data) { $( '#serverResponse').html(data.status + " : " + data.statusText + " : " + data.responseText); } }); </script> ~~~ ## 场景二 如上,通过$('#postForm').serialize()可以对form表单进行序列化,从而将form表单中的所有参数传递到服务端。 但是上述方式,只能传递一般的参数,上传文件的文件流是无法被序列化并传递的。如今主流浏览器都开始支持一个叫做FormData的对象,通过FormData对象,可以使用一系列的键值对来模拟一个完整的表单,然后使用XMLHttpRequest发送这个"表单",这样我们就可以轻松地实现文件上传了。 ~~~ <form id="uploadForm" enctype="multipart/form-data" method="post" name="fileinfo"> <input id="file" type="file"/> <button id="upload" type="button">upload</button> </div> <script type="text/javascript"> var oData = new FormData(document.forms.namedItem("fileinfo" )); oData.append('file', $('#file')[0].files[0]); var oReq = new XMLHttpRequest(); oReq.open( "POST", "/upload.php" , true ); oReq.onload = function(oEvent) { if (oReq.status == 200) { oOutput.innerHTML = "Uploaded!" ; } else { oOutput.innerHTML = "Error " + oReq.status + " occurred uploading your file.<br \/>"; } }; oReq.send(oData); </script> ~~~ ## 场景三 上面的例子中,我们看到上传文件部分是使用底层的XMLHttpRequest对象发送上传请求,那么怎么通过jQuery的Ajax上传呢? 接下来将介绍通过jQuery使用FormData对象上传文件。 #### 方法一:使用`<form>`表单初始化FormData对象方式上传文件 ~~~ <form id="uploadForm" enctype="multipart/form-data"> <input id="file" type="file" name="file"/> <button id="upload" type="button" onclick="doUpload()">upload</button> </form> <script type="text/javascript"> function doUpload() { var formData = new FormData($( "#uploadForm" )[0]); $.ajax({ url: '/upload', type: 'POST', dataType: Json, data: formData, async: false, cache: false, contentType: false, processData: false, success: function (returndata) { alert(returndata); }, error: function (returndata) { alert(returndata); } }); } </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对象添加字段方式上传文件 ~~~ <div id="uploadForm"> <input id="file" type="file"/> <button id="upload" type="button" onclick="doUpload()">upload</button> </div> ~~~ 这里没有`<form>`标签,也没有enctype="multipart/form-data"属性。 ~~~ <script type="text/javascript"> function doUpload() { var formData = new FormData(); formData.append('file', $('#file')[0].files[0]); $.ajax({ url: '/upload', type: 'POST', dataType: Json, data: formData, async: false, cache: false, contentType: false, processData: false }).done(function(res) { }).fail(function(res) {}); } </script> ~~~ 这里和方法一有几处不一样: * append()的第二个参数应是文件对象,即$('#file')[0].files[0]。 * contentType也要设置为‘false’。 * 从代码$('#file')[0].files[0]中可以看到一个`<input type="file">`标签能够上传多个文件,只需要在`<input type="file">`里添加multiple或multiple="multiple"属性。