本文介紹了webuploader分片上傳的實現(xiàn)代碼(前后端分離),分享給大家,具體如下:
創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),邗江企業(yè)網(wǎng)站建設(shè),邗江品牌網(wǎng)站建設(shè),網(wǎng)站定制,邗江網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,邗江網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。
WebUploader是由Baidu WebFE(FEX)團(tuán)隊開發(fā)的一個簡單的以HTML5為主,F(xiàn)LASH為輔的現(xiàn)代文件上傳組件。在現(xiàn)代的瀏覽器里面能充分發(fā)揮HTML5的優(yōu)勢,同時又不摒棄主流IE瀏覽器,沿用原來的FLASH運行時,兼容IE6+,iOS 6+, android 4+。兩套運行時,同樣的調(diào)用方式,可供用戶任意選用。采用大文件分片并發(fā)上傳,極大的提高了文件上傳效率。(這個是從官網(wǎng)上直接copy的解釋)
功能描述
1、webuploader是百度研發(fā)的上傳組件,文檔不是特別規(guī)整,但是也夠用了。
2、前端使用官網(wǎng)的上傳圖片demo,在此基礎(chǔ)上代碼略微調(diào)整做分片。既可以上傳圖片也可以上傳文件。文件超過分片大小才啟用分片。
3、分片上傳已做md5校驗,達(dá)到秒傳的效果。分片以后需要合并,可以先分片后合并,也可以邊分片邊合并,本示例采用的是邊分片邊合并的方案。
4、后端用springboot做框架搭建。springMVC做rest服務(wù),開啟跨域訪問。
5、容器用springboot內(nèi)置的tomcat插件,運行Application的main方法即可啟動服務(wù);
顯示效果
關(guān)鍵代碼前端
WebUploader.Uploader.register({ 'name': 'webUploaderHookCommand', 'before-send-file': 'beforeSendFile', "before-send": "beforeSend" }, { beforeSendFile: function(file) { var task = new WebUploader.Deferred(); fileName = file.name; fileSize = file.size; (new WebUploader.Uploader()).md5File(file, 0, 10 * 1024 * 1024).progress(function(percentage) {}).then(function(val) { fileMd5 = val; var url = checkUrl; var data = { type: 0, fileName: fileName, fileMd5: fileMd5, fileSize: fileSize }; $.ajax({ type: "POST", url: url, data: data, cache: false, async: false, // 同步 timeout: 1000, // todo 超時的話,只能認(rèn)為該分片未上傳過 dataType: "json", error: function(XMLHttpRequest, textStatus, errorThrown) { file.statusText = 'server_error'; task.reject(); } }).then(function(data, textStatus, jqXHR) { if(data.rtn == 0) { if(data.obj == 1) { file.statusText = 'file_existed'; task.reject(); } else { task.resolve(); } } else { task.reject(); } }); }); return task.promise(); }, beforeSend: function(block) { var task = new WebUploader.Deferred(); var url = checkUrl; var data = { type: 1, fileName: fileName, fileMd5: fileMd5, chunk: block.chunk, fileSize: block.end - block.start }; $.ajax({ type: "POST", url: url, data: data, cache: false, async: false, // 同步 timeout: 1000, // todo 超時的話,只能認(rèn)為該分片未上傳過 dataType: "json" }).then(function(data, textStatus, jqXHR) { if(data.rtn == 0 && data.obj == 1) { task.reject(); // 分片存在,則跳過上傳 } else { task.resolve(); } }); this.owner.options.formData.fileMd5 = fileMd5; this.owner.options.formData.chunkSize = chunkSize; return task.promise(); } }); // 實例化 uploader = WebUploader.create({ pick: { id: '#filePicker', label: '點擊選擇文件' }, formData: { uid: 123 }, dnd: '#dndArea', //指定文件拖拽的區(qū)域 paste: '#uploader', //指定監(jiān)聽paste事件的容器,如果不指定,不啟用此功能。此功能為通過粘貼來添加截屏的圖片。建議設(shè)置為document.body. swf: '../plugins/webuploader/Uploader.swf', chunked: true, chunkSize: chunkSize, chunkRetry: false, threads: 1, server: uploadUrl, // runtimeOrder: 'flash', // accept: { // title: 'Images', // extensions: 'gif,jpg,jpeg,bmp,png', // mimeTypes: 'image/*' // }, // 禁掉全局的拖拽功能。這樣不會出現(xiàn)圖片拖進(jìn)頁面的時候,把圖片打開。 disableGlobalDnd: true, fileNumLimit: 300 //限制多文件上傳的個數(shù) //fileSizeLimit: 200 * 1024 * 1024, // 限制所有文件的大小 200 M //fileSingleSizeLimit: 50 * 1024 * 1024 // 限制單個文件的大小 50 M });
后端
import java.io.File; import java.io.IOException; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Service; import org.springframework.web.multipart.MultipartFile; import com.bear.upload.util.FileUtil; import com.bear.upload.util.RETURN; import com.bear.upload.vo.CheckMd5FileVO; import com.bear.upload.vo.UploadVO; @Service public class ChunkUploadService { private static Logger LOG = LoggerFactory.getLogger(ChunkUploadService.class); @Value("${file.upload.path}") private String UPLOAD_PATH; private static final String Delimiter = "-"; /** * 上傳之前校驗(整個文件、分片) * * @param md5FileVO * @return */ public Object check(CheckMd5FileVO md5FileVO) { Integer type = md5FileVO.getType(); Long chunk = md5FileVO.getChunk(); String fileName = md5FileVO.getFileName(); Long fileSize = md5FileVO.getFileSize(); if (type == 0) {// 未分片校驗 String destfilePath = UPLOAD_PATH + File.separator + fileName; File destFile = new File(destfilePath); if (destFile.exists() && destFile.length() == fileSize) { return RETURN.success("文件已存在,跳過", 1); } else { return RETURN.success("文件不存在", 0); } } else {// 分片校驗 String fileMd5 = md5FileVO.getFileMd5(); String destFileDir = UPLOAD_PATH + File.separator + fileMd5; String destFileName = chunk + Delimiter + fileName; String destFilePath = destFileDir + File.separator + destFileName; File destFile = new File(destFilePath); if (destFile.exists() && destFile.length() == fileSize) { return RETURN.success("分片已存在,跳過", 1); } else { return RETURN.success("分片不存在", 0); } } } /** * 文件上傳 * * @param file * @param uploadVO * @param appVersion * @return */ public Object upload(MultipartFile file, UploadVO uploadVO) { Long chunk = uploadVO.getChunk(); if (chunk == null) {// 沒有分片 return UnChunkUpload(file, uploadVO); } else {// 分片 return ChunkUpload(file, uploadVO); } } /** * 分片上傳 * * @param file * @param uploadVO * @param appVersion * @return */ public Object ChunkUpload(MultipartFile file, UploadVO uploadVO) { String fileName = uploadVO.getName(); String fileMd5 = uploadVO.getFileMd5(); Long chunk = uploadVO.getChunk();// 當(dāng)前片 Long chunks = uploadVO.getChunks();// 總共多少片 // 分片目錄創(chuàng)建 String chunkDirPath = UPLOAD_PATH + File.separator + fileMd5; File chunkDir = new File(chunkDirPath); if (!chunkDir.exists()) { chunkDir.mkdirs(); } // 分片文件上傳 String chunkFileName = chunk + Delimiter + fileName; String chunkFilePath = chunkDir + File.separator + chunkFileName; File chunkFile = new File(chunkFilePath); try { file.transferTo(chunkFile); } catch (Exception e) { LOG.error("分片上傳出錯", e); return RETURN.fail("分片上傳出錯", 1); } // 合并分片 Long chunkSize = uploadVO.getChunkSize(); long seek = chunkSize * chunk; String destFilePath = UPLOAD_PATH + File.separator + fileName; File destFile = new File(destFilePath); if (chunkFile.length() > 0) { try { FileUtil.randomAccessFile(chunkFile, destFile, seek); } catch (IOException e) { LOG.error("分片{}合并失?。簕}", chunkFile.getName(), e.getMessage()); return RETURN.fail("分片合并失敗", 1); } } if (chunk == chunks - 1) { // 刪除分片文件夾 FileUtil.deleteDirectory(chunkDirPath); return RETURN.success("上傳成功", 1); } else { return RETURN.fail("上傳中...", 1); } } /** * 未分片上傳 * * @param file * @param uploadVO * @param appVersion * @return */ public Object UnChunkUpload(MultipartFile file, UploadVO uploadVO) { String fileName = uploadVO.getName(); // String fileMd5 = uploadVO.getFileMd5(); // 文件上傳 File destFile = new File(UPLOAD_PATH + File.separator + fileName); if (file != null && !file.isEmpty()) { // 上傳目錄 File fileDir = new File(UPLOAD_PATH); if (!fileDir.exists()) { fileDir.mkdirs(); } if (destFile.exists()) { destFile.delete(); } try { file.transferTo(destFile); return RETURN.success("上傳成功", 0); } catch (Exception e) { LOG.error("文件上傳出錯", e); return RETURN.fail("文件上傳出錯", 0); } } return RETURN.fail("上傳失敗", 0); } }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。
文章題目:webuploader分片上傳的實現(xiàn)代碼(前后端分離)
URL分享:http://aaarwkj.com/article36/goohpg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供域名注冊、服務(wù)器托管、網(wǎng)站內(nèi)鏈、定制開發(fā)、企業(yè)建站、響應(yīng)式網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)