<!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>