大文件分片上傳,斷點續傳,秒傳 實現

關鍵部分javascript

前端用file.slice()分塊css

前端用FileReader獲取每一分塊的md5值html

後端用MultipartFile接受分塊文件前端

後端用FileOutputStream拼裝分塊文件java

話很少說,直接上代碼,我想這是大家最喜歡的jquery

工程截圖算法

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%><%json

String path = request.getContextPath();後端

String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";服務器

String clientCookie = request.getHeader("Cookie");

%><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html>

  <head>

     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

    <title>up6.2-MySQL演示頁面</title>

    <link href="js/up6.css" type="text/css" rel="Stylesheet"/>

    <script type="text/javascript" src="js/jquery-1.4.min.js"></script>

    <script type="text/javascript" src="js/json2.min.js" charset="utf-8"></script>

    <script type="text/javascript" src="js/up6.config.js" charset="utf-8"></script>

    <script type="text/javascript" src="js/up6.app.js" charset="utf-8"></script>

    <script type="text/javascript" src="js/up6.edge.js" charset="utf-8"></script>

    <script type="text/javascript" src="js/up6.file.js" charset="utf-8"></script>

    <script type="text/javascript" src="js/up6.folder.js" charset="utf-8"></script>

    <script type="text/javascript" src="js/up6.js" charset="utf-8"></script>

    <script language="javascript" type="text/javascript">

    var cbMgr = new HttpUploaderMgr();

    cbMgr.event.md5Complete = function (obj, md5) { /*alert(md5);*/ };

     cbMgr.event.fileComplete = function (obj) { /*alert(obj.pathSvr);*/ };

    cbMgr.Config["Cookie"] = 'JSESSIONID=<%=request.getSession().getId()%>';

    cbMgr.Config.Fields["test"] = "test";

 

    $(function()

    {

         cbMgr.load_to("FilePanel");//加載控件

        });

    </script>

  </head>

 

  <body>

     <p>up6.2多文件上傳演示頁面</p>

     <div id="FilePanel"></div>

     <div id="msg"></div>

  </body>

</html>

 

文件MD5計算

     /**

      * 把文件轉成md5字符串

      * @param file

      * @return

      */

     public static String fileToMD5(File file) {

         if(file == null) {

              return null;

         }

         if(file.exists() == false) {

              return null;

         }

         if(file.isFile() == false) {

              return null;

         }

         FileInputStream fis = null;

         try {

              //建立一個提供信息摘要算法的對象,初始化爲md5算法對象

              MessageDigest md = MessageDigest.getInstance("MD5");

              fis = new FileInputStream(file);

              byte[] buff = new byte[1024];

              int len = 0;

              while(true) {

                   len = fis.read(buff, 0, buff.length);

                   if(len == -1){

                       break;

                   }

                   //每次循環讀取必定的字節都更新

                   md.update(buff,0,len);

              }

              //關閉流

              fis.close();

              //返回md5字符串

              return bytesToHex(md.digest());

         } catch (Exception e) {

              e.printStackTrace();

         }

         return null;

     }

 

文件夾文件夾名稱生成邏輯

package up6.biz;

import java.io.IOException;

import java.text.SimpleDateFormat;

import java.util.Date;

import java.util.UUID;

import up6.model.FileInf;

public class PathBuilderUuid extends PathBuilder{

     /* 生成文件夾存儲路徑,徹底與客戶端文件夾結構保持一致

      * 格式:    

      *  upload/2016/05/17/uuid/folder_name

      * 更新記錄:

      *  2016-03-01 upload/uid/folders/uuid/folder_name

      *   2016-05-17 將格式改成日期格式

      *

      */

     public String genFolder(int uid,String nameLoc) throws IOException

     {

         SimpleDateFormat fmtDD = new SimpleDateFormat("dd");

         SimpleDateFormat fmtMM = new SimpleDateFormat("MM");

         SimpleDateFormat fmtYY = new SimpleDateFormat("yyyy");

        

         Date date = new Date();

         String strDD = fmtDD.format(date);

         String strMM = fmtMM.format(date);

         String strYY = fmtYY.format(date);

        

         String uuid = UUID.randomUUID().toString();

         uuid = uuid.replace("-","");

        

         String path = this.getRoot() + "/";

         path = path.concat(strYY);

         path = path.concat("/");

         path = path.concat(strMM);

         path = path.concat("/");

         path = path.concat(strDD);

         path = path.concat("/");

        

         path = path.concat(uuid);

         path = path.concat("/");

         path = path.concat(nameLoc);

         return path;

     }

    

     /* 保留原始文件名稱,不檢查文件是否重複

      * 格式:

      *   upload/uid/年/月/日/uuid/file_name

      * @see Xproer.PathBuilder#genFile(int, Xproer.xdb_files)

      */

     public String genFile(int uid,FileInf f) throws IOException{

         String uuid = UUID.randomUUID().toString();

         uuid = uuid.replace("-", "");

        

 

         SimpleDateFormat fmtDD = new SimpleDateFormat("dd");

         SimpleDateFormat fmtMM = new SimpleDateFormat("MM");

         SimpleDateFormat fmtYY = new SimpleDateFormat("yyyy");

        

         Date date = new Date();

         String strDD = fmtDD.format(date);

         String strMM = fmtMM.format(date);

         String strYY = fmtYY.format(date);

        

         String path = this.getRoot() + "/";

         path = path.concat(strYY);

         path = path.concat("/");

         path = path.concat(strMM);

         path = path.concat("/");

         path = path.concat(strDD);

         path = path.concat("/");

         path = path.concat(uuid);

         path = path.concat("/");

         path = path.concat(f.nameLoc);

         return path;

     }

}

文件上傳的效果

http://bbsres2.ncmem.com/4f09f40c.png

 

文件保存位置及邏輯

在up6中有兩種保存模式,一種是md5一種是uuid。

md5由PathBuilderMd5生成存儲路徑。md5主要提供給文件使用,可在服務器端保存惟一的文件,有效避免重複文件。

uuid由PathBuilderUuid生成存儲路徑。uuid主要提供給文件夾使用,能夠與本地文件夾結構徹底保持一致。使用uuid模式上傳文件夾時秒傳功能會失效。

 

文件默認保存位置在項目路徑下:

http://bbsres2.ncmem.com/3b3d0785.png

demo會自動生成upload文件夾

規則:upload/年/月/日/md5

http://bbsres2.ncmem.com/8d7cf154.png

 

代碼截圖:

http://bbsres2.ncmem.com/a3f89d66.png

 

http://bbsres2.ncmem.com/8e9fedc0.png

 

http://bbsres2.ncmem.com/65723f73.png

 

文件邏輯:

http://bbsres2.ncmem.com/a7f73af8.png

生成文件服務器存儲路徑

http://bbsres2.ncmem.com/df2f0fb4.png

 

文件夾邏輯:

http://bbsres2.ncmem.com/a72ba00f.png

http://bbsres2.ncmem.com/e5e3c5dc.png

生成文件夾存儲路徑

 

http://bbsres2.ncmem.com/516e2826.png

生成子文件路徑

 

http://bbsres2.ncmem.com/64d1b40f.png

生成子目錄路徑

 

http://bbsres2.ncmem.com/00989477.png

DEMO下載地址:https://dwz.cn/fgXtRtnu 

相關文章
相關標籤/搜索