利用 FormData 對(duì)象和 Spring MVC 配合實(shí)現(xiàn)Ajax文件下載功能
Ajax文件下載
利用 FormData 對(duì)象和 Spring MVC 配合可以實(shí)現(xiàn)Ajax文件上載功能:
步驟
1.導(dǎo)入組件并準(zhǔn)備靜態(tài)腳本
<dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.3.2</version> </dependency> <h1>Ajax 文件上載</h1> <input type="file" id="file1"> <br> <input type="file" id="file2"> <br> <input type="button" id="upload" value="上載" > <div id="result"></div>
1.綁定事件到按鈕
$("upload").click(ajaxUpload);
2.獲取文件
var file1 = $("#file1")[0].files[0]; var file2 = $("#file2")[0].files[0];
3.創(chuàng)建內(nèi)存中的表單對(duì)象,并添加向服務(wù)器傳輸?shù)臄?shù)據(jù)
//創(chuàng)建內(nèi)存中的表單對(duì)象 var form = new FormData(); //向其中添加要傳輸?shù)臄?shù)據(jù) form.append("userfile1", file1); form.append("userfile2", file2);
4.ajax()上傳對(duì)象
$.ajax({ url:'user/upload.do',//請(qǐng)求地址 data: form, //請(qǐng)求參數(shù) type: 'POST', //請(qǐng)求類型 dataType: 'json',//服務(wù)器返回的數(shù)據(jù)類型 contentType: false,//沒有設(shè)置任何內(nèi)容類型頭信息 processData: false, //見jQuery_api詳解 success: function(obj){ //成功時(shí)回調(diào)函數(shù),obj表示服務(wù)器返回的數(shù)據(jù) if(obj.state==0){ $('#result').html("成功!"); } } });
5.Spring-MVC表現(xiàn)層
@RequestMapping("/upload.do") @ResponseBody public JsonResult upload( MultipartFile userfile1, MultipartFile userfile2) throws Exception{ //Spring MVC 中可以利用 MultipartFile //接收 上載的文件! 文件中的一切數(shù)據(jù) //都可以從 MultipartFile 對(duì)象中找到 //獲取上再是原始文件名 String file1 = userfile1.getOriginalFilename(); String file2 = userfile2.getOriginalFilename(); System.out.println(file1); System.out.println(file2); //保存文件的3種方法: //1. transferTo(目標(biāo)文件) // 將文件直接保存到目標(biāo)文件, 可以處理大文件 //2. userfile1.getBytes() 獲取文件的全部數(shù)據(jù) // 將文件全部讀取到內(nèi)存, 適合處理小文件!! //3. userfile1.getInputStream() // 獲取上載文件的流, 適合處理大文件 //保存的目標(biāo)文件夾: /home/soft01/demo File dir = new File("D:/demo"); dir.mkdir(); File f1 = new File(dir, file1); File f2 = new File(dir, file2); //第一種保存文件 //userfile1.transferTo(f1); //userfile2.transferTo(f2); //第三種 利用流復(fù)制數(shù)據(jù) InputStream in1 = userfile1.getInputStream(); FileOutputStream out1 = new FileOutputStream(f1); int b; while((b=in1.read())!=-1){ out1.write(b); } in1.close(); out1.close(); InputStream in2 = userfile2.getInputStream(); FileOutputStream out2= new FileOutputStream(f2); byte[] buf= new byte[8*1024]; int n; while((n=in2.read(buf))!=-1){ out2.write(buf, 0, n); } in2.close(); out2.close(); return new JsonResult(true); }
總結(jié)
以上所述是小編給大家介紹的利用 FormData 對(duì)象和 Spring MVC 配合實(shí)現(xiàn)Ajax文件下載功能,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- ajax post下載flask文件流以及中文文件名問(wèn)題
- javascript寫一個(gè)ajax自動(dòng)攔截并下載數(shù)據(jù)代碼實(shí)例
- SpringMVC+Ajax實(shí)現(xiàn)文件批量上傳和下載功能實(shí)例代碼
- Ajax請(qǐng)求二進(jìn)制流進(jìn)行處理(ajax異步下載文件)的簡(jiǎn)單方法
- 基于Blod的ajax進(jìn)度條下載實(shí)現(xiàn)示例代碼
- PHP中ajax無(wú)刷新上傳圖片與圖片下載功能
- 使用Ajax生成的Excel文件并下載的實(shí)例
- jQuery的ajax下載blob文件
- jQuery+Ajax+PHP彈出層異步登錄效果(附源碼下載)
- PHP+Ajax實(shí)現(xiàn)無(wú)刷新分頁(yè)實(shí)例詳解(附demo源碼下載)
- 前端ajax請(qǐng)求+后端java實(shí)現(xiàn)的下載zip壓縮包功能示例
相關(guān)文章
asp.net+ajax簡(jiǎn)單分頁(yè)實(shí)例分析
這篇文章主要介紹了asp.net+ajax簡(jiǎn)單分頁(yè)實(shí)現(xiàn)方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了ajax分頁(yè)的具體實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-12-12登錄超時(shí)給出提示跳到登錄頁(yè)面(ajax、導(dǎo)入、導(dǎo)出)
這篇文章主要介紹了登錄超時(shí)給出提示跳到登錄頁(yè)面(ajax、導(dǎo)入、導(dǎo)出)的相關(guān)資料,需要的朋友可以參考下2016-02-02使用$.get()根據(jù)選項(xiàng)的不同從數(shù)據(jù)庫(kù)異步請(qǐng)求數(shù)據(jù)
本例實(shí)現(xiàn)的是這樣的一個(gè)效果:當(dāng)從select下拉框選擇編程語(yǔ)言時(shí)時(shí),根據(jù)選項(xiàng)的不同,異步請(qǐng)求不同的函數(shù)API描述,需要的朋友可以參考下2014-04-04如何利用jQuery post傳遞含特殊字符的數(shù)據(jù)
在jquery中,解決數(shù)據(jù)傳遞處理的方法我們通常利用$.ajax或$.post,但是這里這里通常不能傳遞特殊字符,比如說(shuō):“<”,本文就幫大家解決如何傳遞這種含特殊字符的數(shù)據(jù),感興趣的朋友一起看下吧2015-10-10ajax獲取數(shù)據(jù)中文亂碼問(wèn)題最簡(jiǎn)單的完美解決方案
這篇文章主要介紹了ajax獲取數(shù)據(jù)中文亂碼問(wèn)題最簡(jiǎn)單的完美解決方案,需要的朋友可以參考下2014-11-11詳解Ajax跨域(jsonp) 調(diào)用JAVA后臺(tái)
本篇文章主要介紹了詳解Ajax跨域(jsonp) 調(diào)用JAVA后臺(tái) ,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-05-05jquery ajax實(shí)現(xiàn)批量刪除具體思路及代碼
回調(diào)函數(shù),在請(qǐng)求完成后需要進(jìn)行的操作:此處是把選中的checkbox去掉,接下來(lái)為大家詳細(xì)介紹下,感興趣的朋友可以參考下哈,希望對(duì)你有所幫助2013-04-04