導航:首頁 > 文件教程 > java文件上傳刪除

java文件上傳刪除

發布時間:2025-05-23 09:34:09

java上傳文件後用戶是如何訪問的(java實現文件上傳的三種方式)

JAVA把文件傳到伺服器.......

文件上傳到A以後放到伺服器上面然後他就有一個絕對的訪問路徑也就是對應一個絕對的url這樣就好辦了

Java提供了對URL訪問和大量的流操作的的API,可以很容易的完成對網路上資源的存取,下面的代碼段就完成了對一個網站的資源進行訪問:

......

destUrl="";

//假設你把文件放到webroot底下的java文件裡面

url=newURL(destUrl);

httpUrl=(HttpURLConnection)url.openConnection();

//連接指定的網路資源

httpUrl.connect();

//獲取網路輸入流

bis=newBufferedInputStream(httpUrl.getInputStream());

......

得到流後下面你自己想怎麼操作就怎麼操作了

對於怎麼得到資源的連接地址這個方法很多你可以專門提供一個Servlet獲取到輸出的流後Response.write轉門提供伺服器已上傳的文件文件名可以一天位單位返回

客戶端用與上面同樣的方法得到文件名後拆分然後再繼續循環調用上面的方法下載文件就ok了

呵呵希望可以幫助到你

如何通過Java客戶端程序通過rest介面訪問並上傳文件(文檔)到web伺服器?

圖片目錄不在項目路徑下,直接通過HTTP訪問不到,如果你硬是要這么訪問,你可以自己寫一個Servlet,通過流的方式輸出,注意要吧Content-Type設置正確

java上傳成功後怎麼觸發其他操作

javaget方式非同步上傳_簡述Java非同步上傳文件的三種方式原創

2021-02-1316:31:03

yibbbian

碼齡4年

關注

本文為大家分享了三種Java非同步上傳文件方式,供大家參考,具體內容如下

用第三方控制項,如Flash,ActiveX等瀏覽器插件上傳。

使用隱藏的iframe模擬非同步上傳。

使用XMLHttpRequest2來實現非同步上傳。

第一種使用瀏覽器插件上傳,需要一定的底層編碼功底,在這里我就不講了,以免誤人子弟,提出這點大家可以自行網路。

第二種使用隱藏的iframe模擬非同步上傳。為什麼在這里說的是模擬呢?因為我們其實是將返回結果放在了一個隱藏的iframe中,所以才沒有使當前頁面跳轉,感覺就像是非同步操作一樣。

隱藏的iframe上傳文件

附件:

正在上傳...

//上傳完成後的回調

functionuploadFinished(fileName){

addToFlist(fileName);

loading(false);

}

functionaddToFlist(fname){

vartemp=["

",

fname,

"刪除",

"

"

];

$("#flist").append(temp.join(""));

}

functionloading(showloading){

if(showloading){

$("#uptxt").show();

}else{

$("#uptxt").hide;

}

}

這種技術有兩個關鍵的地方:

1.form會指定target,提交的結果定向返回到隱藏的ifram中。(即form的target與iframe的name屬性一致)。

2.提交完成後,iframe中頁面與主頁面通信,通知上傳結果及服務端文件信息

如何與主頁面通信呢?

我們用nodejs在接收完了文件後返回了一個window.parent.主頁面定義的方法,執行後可以得知文件上傳完成。代碼很簡單:

router.post('/upload2',multipartMiddleware,function(req,res){

varfpath=req.files.myfile.path;

varfname=fpath.substr(fpath.lastIndexOf('\')+1);

setTimeout(function{

varret=["

"window.parent.uploadFinished('"+fname+"');",

""];

res.send(ret.join(""));

},3000);

});

執行後可以打開開發人員選項,你會發現隱藏iframe中返回了伺服器的一些數據。

第三種使用XMLHttpRequest2來進行真正的非同步上傳。

還是先貼出代碼:

執行後可以打開開發人員選項,你會發現隱藏iframe中返回了伺服器的一些數據。第三種使用XMLHttpRequest2來進行真正的非同步上傳。還是先貼出代碼:

xhrlevel2非同步上傳

附件:

正在上傳...

停止上傳

functionupload{

//1.准備FormData

varfd=newFormData;

fd.append("myfile",$("#myfile")[0].files[0]);

//創建xhr對象

varxhr=newXMLHttpRequest;

//監聽狀態,實時響應

//xhr和xhr.upload都有progress事件,xhr.progress是下載進度,xhr.upload.progress是上傳進度

xhr.upload.onprogress=function(event){

if(event.lengthComputable){

varpercent=Math.round(event.loaded*100/event.total);

console.log('%d%',percent);

$("#upprog").text(percent);

}

};

//傳輸開始事件

xhr.onloadstart=function(event){

console.log('loadstart');

$("#upprog").text('開始上傳');

$("#stopbtn").one('click',function{xhr.abort;$(this).hide();});

loading(true);

};

//ajax過程成功完成事件

xhr.onload=function(event){

console.log('loadsuccess');

$("#upprog").text('上傳成功');

console.log(xhr.responseText);

varret=JSON.parse(xhr.responseText);

addToFlist(ret.fname);

};

//ajax過程發生錯誤事件

xhr.onerror=function(event){

console.log('error');

$("#upprog").text('發生錯誤');

};

//ajax被取消

xhr.onabort=function(event){

console.log('abort');

$("#upprog").text('操作被取消');

};

//loadend傳輸結束,不管成功失敗都會被觸發

xhr.onloadend=function(event){

console.log('loadend');

loading(false);

};

//發起ajax請求傳送數據

xhr.open('POST','/upload3',true);

xhr.send(fd);

}

functionaddToFlist(fname){

vartemp=["

",

fname,

"刪除",

"

"

];

$("#flist").append(temp.join(""));

}

functiondelFile(fname){

console.log('todeletefile:'+fname);

//TODO:請實現

}

functionloading(showloading){

if(showloading){

$("#uptxt").show();

$("#stopbtn").show();

}else{

$("#uptxt").hide();

$("#stopbtn").hide();

}

}

代碼有點多,但是通俗易懂。使用過AJAX的人都知道,XHR對象提供了一個onreadystatechange的回調方法來監聽整個請求/響應過程。在XMLHttpRequest2級規范中又多了幾個進度事件。有以下6個事件:

1.loadstart:在接收到響應數據的第一個位元組時觸發。

2.progress:在接收響應期間持續不斷地觸發。

3.error:在請求發生錯誤時觸發。

4.abort:在因為調用abort方法而終止連接時觸發。

5.load:在接收到完整的響應數據時觸發。

6.loadend:在通信完成或者觸發error,abort,load事件後觸發。

這次我們可以解讀代碼:當傳輸事件開始後,我們便在停止傳送按鈕上添加點擊事件,內置了abort方法可以停止傳送。若不點則會正常上傳直到傳送完畢為止。其後台代碼類似第二種方法。

三種方法各有優劣,做個簡單的小結吧。

第三方控制項交互性和可控性好,因為接近底層,其性能也是很優秀的。但是由於編寫難度大通常需要自己安裝插件,有時可能需要自己進行編寫。

隱藏的iframe方法我個人覺得是非常有思想的一個方法,iframe可以幫我們做很多事。這種方式具有廣泛的瀏覽器兼容性而且不需要安裝插件。但是它交互性差,上傳過程不可控,而且性能也是很一般的。

XHR2級的純ajax上傳,它必須要版本比較高一點的瀏覽器(ie9+)。但是它交互性特別好,可以看到上傳進度並且是可控的。

java如何訪問區域網共享文件?

java訪問共享文件夾,讀取區域網中一台機器的共享目錄中的文件,需要jcifs-1.1.11.jar的支持,使用SMB協議,以下是實現了遠程讀取文件的功能代碼:

package?junit;

import?jcifs.smb.SmbFile;

/**???

?*?java訪問區域網共享目錄

?*

?*?@author?administrator

?*?@version?1.0?2015-7-6?

?*/

public?class?SmbTest?{

????public?static?void?main(String[]?args)?throws?Exception?{

????????//smb://xxx:[email protected]/testIndex/??

????????//xxx:xxx是共享機器的用戶名密碼

????????String?url="smb://192.168.2.188/testIndex/";

????????SmbFile?file?=?new?SmbFile(url);

????????if(file.exists()){

????????????SmbFile[]?files?=?file.listFiles();

????????????for(SmbFile?f?:?files){

????????????????System.out.println(f.getName());

????????????}

????????}

????}

}

java文件上傳後,一般怎麼和用戶掛鉤呢?

第一個問題,如果有單獨的文件伺服器,上傳的每一個文件有一個唯一的id,{id,filePath},id與用戶關聯即可.

第二個問題,可以一組文件分配一個id,表示這些文件是一個組的,id與用戶關聯.

閱讀全文

與java文件上傳刪除相關的資料

熱點內容
php文件名擴展名 瀏覽:762
抖音在app內升不了級怎麼辦 瀏覽:66
cf不掉血文件2014 瀏覽:736
word批量發送郵件 瀏覽:241
兩個iso文件怎麼安裝 瀏覽:281
delphi網路埠調試助手 瀏覽:22
創維機盒wifi輸入密碼 瀏覽:307
海迅設計軟體支持什麼格式的文件 瀏覽:645
熊貓麻將分享哪個app 瀏覽:832
linux下創建文本文件 瀏覽:782
iuni最新版本 瀏覽:614
如何在設置中打開應用網路 瀏覽:125
花椰菜網路語是什麼意思 瀏覽:165
編程貓怎麼換東西 瀏覽:857
win10進win7網路共享文件夾進不去 瀏覽:74
微信選擇一個群找不到了 瀏覽:15
java高級io 瀏覽:30
4000mah能充多少電蘋果 瀏覽:957
返利app哪裡找 瀏覽:852
win10文件隨意拖動排列 瀏覽:870

友情鏈接