關鍵部分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;
}
}
文件上傳的效果
文件保存位置及邏輯
在up6中有兩種保存模式,一種是md5一種是uuid。
md5由PathBuilderMd5生成存儲路徑。md5主要提供給文件使用,可在服務器端保存惟一的文件,有效避免重複文件。
uuid由PathBuilderUuid生成存儲路徑。uuid主要提供給文件夾使用,能夠與本地文件夾結構徹底保持一致。使用uuid模式上傳文件夾時秒傳功能會失效。
文件默認保存位置在項目路徑下:
demo會自動生成upload文件夾
規則:upload/年/月/日/md5
代碼截圖:
文件邏輯:
生成文件服務器存儲路徑
文件夾邏輯:
生成文件夾存儲路徑
生成子文件路徑
生成子目錄路徑
DEMO下載地址:https://dwz.cn/fgXtRtnu