<!DOCTYPE> <html> <head> <meta charset="UTF-8"> <title> formdata file jquery ajax upload</title> </head> <body> <form id="uploadForm" enctype="multipart/form-data"> <input id="file" type="file" name="file"/> <button id="upload" type="button">upload</button> </form> <script src="jquery-1.9.1.min.js"></script> <script type="text/javascript"> var btn=$('#upload'); btn.click(function () { $.ajax({ url: '/ls/Upfile', type: 'POST', cache: false,// cache设置为false,上传文件不需要缓存。 data: new FormData($('#uploadForm')[0]), processData: false,//processData设置为false。因为data值是FormData对象,不需要对数据做处理。 contentType: false// contentType设置为false,不设置contentType值,因为是由<form>表单构造的FormData对象,且已经声明了属性enctype="multipart/form-data",所以这里设置为false。 }).done(function(res) { console.log(res) }).fail(function(res) { }) } ); /* <form>标签添加enctype="multipart/form-data"属性。 上传后,服务器端代码需要使用从查询参数名为file获取文件输入流对象,因为<input>中声明的是name="file"。 从Servlet 3.0 开始,可以通过 request.getPart() 或 request.getPars() 两个接口获取上传的文件。 */ </script> </body> </html>
来源:https://www.cnblogs.com/xiaobaibubai/p/7126397.html