當前位置:首頁 » 文件管理 » java上傳圖片插件

java上傳圖片插件

發布時間: 2025-09-13 12:31:54

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怎樣實現跨伺服器文件上傳

你好!


另一台機器也要有處理文件上傳的WEB程序鄭慶,你可以喊蠢握參考Stream上傳插件(支持HTML5和Flash兩種方式上傳)


Stream 上傳插件

Stream 是解決不同瀏覽器上傳文件的插件,是Uploadify的Flash版和Html5版的結合!


Stream 簡介

Stream 是根據某網的文件上傳插件加工而來,支持不同平台(Windows, Linux, Mac, Android, iOS)下,主流瀏覽器(IE7+, Chrome, Firefox, Safari, 其他)的上傳工作,當然在Html5標准下,還支持文件檔如的斷點續傳功能,有效解決大文件的Web上傳問題!


主要特徵

1. 源碼完全開放,目前有Java、PHP、Perl三種後台語言實現


2. 支持HTML5、Flash兩種方式(跨域)上傳


3. 多文件一起上傳


4. HTML5支持斷點續傳,拖拽等新特性


5. 兼容性好IE7+, FF3.6+, Chrome*,Safari4+,遨遊等主流瀏覽器


6. 進度條、速度、剩餘時間等附屬信息


7. `選擇文件的按鈕`可以自定義


8. 簡單的參數配置實現 靈活多變的功能


9. 支持文件夾上傳(Chrome21+, Opera15+)


10. 支持自定義UI(V1.4+)


指定跨域上傳就可以了


這些都是小鳥雲的工程師告訴我的,建議你可以試試小鳥雲

熱點內容
如何設置windows密碼 發布:2025-09-13 15:17:29 瀏覽:953
sql北京 發布:2025-09-13 15:11:34 瀏覽:220
腳本怎麼保存 發布:2025-09-13 15:11:29 瀏覽:645
安卓軟體下載證書在哪裡 發布:2025-09-13 15:10:51 瀏覽:449
解壓擺球 發布:2025-09-13 14:47:22 瀏覽:211
源碼下載靠譜 發布:2025-09-13 14:27:30 瀏覽:959
倉庫解壓碼流 發布:2025-09-13 14:20:30 瀏覽:890
在線編程少兒 發布:2025-09-13 14:19:29 瀏覽:386
365文檔的停止保護密碼是多少 發布:2025-09-13 14:04:18 瀏覽:143
c語言二級編程題 發布:2025-09-13 13:59:09 瀏覽:837