java大文件解析_java大文件(百M以上)的上传下载实例解析
javaweb上傳文件
上傳文件的jsp中的部分
上傳文件同樣可以使用form表單向后端發(fā)請(qǐng)求,也可以使用 ajax向后端發(fā)請(qǐng)求
1.通過form表單向后端發(fā)送請(qǐng)求
Save
改進(jìn)后的代碼不需要form標(biāo)簽,直接由控件來實(shí)現(xiàn)。開發(fā)人員只需要關(guān)注業(yè)務(wù)邏輯即可。JS中已經(jīng)幫我們封閉好了
通過監(jiān)控工具可以看到控件提交的數(shù)據(jù),非常的清晰,調(diào)試也非常的簡(jiǎn)單。
2.通過ajax向后端發(fā)送請(qǐng)求
1.
$.ajax({
url :“${pageContext.request.contextPath}/UploadServlet”,
type:“POST”,
data : $(‘#postForm’).serialize(),
success :function(data){
$(‘#serverResponse’).html(data);
},
error:function(data){
$(‘#serverResponse’).html(data.status+” : “+ data.statusText +” : “+ data.responseText);
}
});
ajax分為兩部分,一部分是初始化,文件在上傳前通過AJAX請(qǐng)求通知服務(wù)端進(jìn)行初始化操作
在文件上傳完后向服務(wù)器發(fā)送通知
這里需要處理一個(gè)MD5秒傳的邏輯,當(dāng)服務(wù)器存在相同文件時(shí),不需要用戶再上傳,而是直接通知用戶秒傳
這里可以看到秒傳的邏輯是非常 簡(jiǎn)單的,并不是特別的復(fù)雜。
var form = new FormData();
form.append(“username”,“zxj”);
form.append(“avatar”,file);
//var form = new FormData($(“#postForm”)[0]);
$.ajax({
url:“${pageContext.request.contextPath}/UploadServlet”,
type:“post”,
data:form,
processData:false,
contentType:false,
success:function(data){
console.log(data);
}
});
java部分
文件初始化的邏輯
接收文件塊數(shù)據(jù),在這個(gè)邏輯中我們接收文件塊數(shù)據(jù)。控件對(duì)數(shù)據(jù)進(jìn)行了優(yōu)化,可以方便調(diào)試。如果用監(jiān)控工具可以看到控件提交的數(shù)據(jù)。
注:
1.上面的java部分的代碼可以直接使用,只需要將上傳的圖片路徑及收集數(shù)據(jù)并將數(shù)據(jù)寫入到數(shù)據(jù)庫即可
2.上面上傳文件使用到了字節(jié)流,其實(shí)還可以使用別的流,這個(gè)需要讀者自己在下面完善測(cè)試
3. BeanUtils是一個(gè)工具 便于將實(shí)體對(duì)應(yīng)的屬性賦給實(shí)體
4.上傳文件不能使用 request.getParameter(“”)獲取參數(shù)了,而是直接將request解析,通過判斷每一項(xiàng)是文件還是非文件,然后進(jìn)行相應(yīng)的操作(文件的話就是用流來讀取,非文件的話,暫時(shí)保存到一個(gè)map中。)
歡迎入群一起討論:374992201
總結(jié)
以上是生活随笔為你收集整理的java大文件解析_java大文件(百M以上)的上传下载实例解析的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 安卓曲线图(安卓曲线)
- 下一篇: linux 容量查询(linux 容量)