Java基于TCP協(xié)議socket網(wǎng)絡(luò)編程的文件傳送的實(shí)現(xiàn)
先了解一下socket基本概念
socket也叫套接字:
是指在網(wǎng)路中不同主機(jī)上的應(yīng)用進(jìn)程之間,進(jìn)行雙向通信的端點(diǎn)的抽象。
簡(jiǎn)單理解就是:
兩個(gè)主機(jī)之間要通信,就需要知道彼此的ip,端口號(hào)等信息,而一臺(tái)主機(jī)這些信息的集合:
就可以理解為一個(gè)端點(diǎn),即為套接字
雙方通過(guò)套接字作為一種坐標(biāo),建立信息通道,形成連接(兩點(diǎn)連接一條直線)
簡(jiǎn)單理解了套接字的概念后,來(lái)看看如何通過(guò)java socket編程來(lái)實(shí)現(xiàn)
兩臺(tái)主機(jī)文件的接收與發(fā)送:
代碼如下:
發(fā)送方:
import java.io.*; import java.net.InetAddress; import java.net.Socket; /** * 發(fā)送者 */ public class TcpSendCilent { public static void main(String[] args) throws Exception { //1.通過(guò)socket對(duì)象 創(chuàng)建socket連接 Socket socket = new Socket(InetAddress.getByName("127.0.0.1"), 9000); //2,創(chuàng)建一個(gè)字節(jié)輸出流 OutputStream os = socket.getOutputStream(); //3.字節(jié)文件輸入流 讀取文件 //避免出錯(cuò) 寫需要發(fā)送文件的絕對(duì)路徑 FileInputStream fis = new FileInputStream(new File("F:/TEST/1604407051256.jpg")); //4.字節(jié)文件輸出流 寫出文件 byte[] buffer=new byte[1024*10]; int len; while ((len=fis.read(buffer))!=-1){ //socket編程基于I/O流 所以 //輸出流寫轉(zhuǎn)為字節(jié)數(shù)組的文件 =向接收方發(fā)送文件 os.write(buffer,0,len); } //通知服務(wù)器我傳送完了 調(diào)用shutdownOutput() 否則影響接下來(lái)代碼執(zhí)行 socket.shutdownOutput(); //確定服務(wù)器接受完畢,斷開(kāi)連接 //獲取接收方響應(yīng)回來(lái)的 接受完畢! 響應(yīng) InputStream inputStream = socket.getInputStream(); ByteArrayOutputStream baos=new ByteArrayOutputStream(); byte[] bytes2=new byte[1024*10]; int len2; while ((len2=inputStream.read(bytes2))!=-1){ baos.write(bytes2,0,len2); } //顯示接收方的響應(yīng) System.out.println(baos.toString()); //發(fā)送結(jié)束后,最后關(guān)閉所有資源 //關(guān)閉資源好習(xí)慣 這部分寫的簡(jiǎn)單 //一般建議先進(jìn)行一個(gè)非空判斷再關(guān)閉 baos.close(); fis.close(); os.close(); socket.close(); } }
接收方:
import java.io.*; import java.net.ServerSocket; import java.net.Socket; /** * 接收端 */ public class TcpAcceptServer { public static void main(String[] args) throws IOException { //通過(guò)ServerSocket對(duì)象 創(chuàng)建接收端套接字 ServerSocket serverSocket=null; //套接字 Socket socket=null; //字節(jié)輸入流 InputStream in=null; //默認(rèn)參數(shù)定義端口號(hào) 發(fā)送方依據(jù)這個(gè)端口號(hào)發(fā)送 serverSocket=new ServerSocket(9000); socket = serverSocket.accept(); //socket對(duì)象 獲取輸入流,拿到文件 in = socket.getInputStream(); //將發(fā)送者發(fā)送過(guò)來(lái)的 文件通過(guò)文件字節(jié)輸出流 輸出到指定路徑下 FileOutputStream fos = new FileOutputStream(new File("F:/recevice.jpg")); int len; byte[] bytes=new byte[1024*10]; while ((len=in.read(bytes))!=-1){ fos.write(bytes,0,len); } //通知發(fā)送者接受完畢了 OutputStream outputStream = socket.getOutputStream(); outputStream.write("我是文件接收者:我已成功接受".getBytes()); //接受結(jié)束后,關(guān)閉資源好習(xí)慣 這部分寫的簡(jiǎn)單 //一般建議先進(jìn)行一個(gè)非空判斷再關(guān)閉 fos.close(); serverSocket.close(); socket.close(); in.close(); } }
測(cè)試方法:
以上代碼可直接粘貼測(cè)試
1、先運(yùn)行接收者等待接受,
2、再運(yùn)行發(fā)送者,
3、等待接收者向發(fā)送者響應(yīng): 我是文件接收者:我已成功接受;
4、接收者指定接受目錄下、查看接收文件存在即為接收成功!
總結(jié):
這個(gè)demo實(shí)現(xiàn)并不是很難,主要考驗(yàn)了我們對(duì)于io流的熟練程度
到此這篇關(guān)于Java基于TCP協(xié)議socket網(wǎng)絡(luò)編程的文件傳送的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Java socket文件傳送內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java中Map如何根據(jù)key的大小進(jìn)行排序詳解
這篇文章主要給大家介紹了關(guān)于java中Map如何根據(jù)key的大小進(jìn)行排序的相關(guān)資料,有時(shí)候我們業(yè)務(wù)上需要對(duì)map里面的值按照key的大小來(lái)進(jìn)行排序的時(shí)候我們就可以利用如下方法來(lái)進(jìn)行排序了,需要的朋友可以參考下2023-09-09java連接mysql數(shù)據(jù)庫(kù)詳細(xì)步驟解析
以下是對(duì)java連接mysql數(shù)據(jù)庫(kù)的具體詳細(xì)步驟進(jìn)行了分析介紹,需要的朋友可以過(guò)來(lái)參考下2013-08-08Springboot遷移到Micronaut實(shí)現(xiàn)過(guò)程詳解
這篇文章主要為大家?介紹了Springboot遷移到Micronaut實(shí)現(xiàn)過(guò)程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05Java利用完全二叉樹(shù)創(chuàng)建大根堆和小根堆
大根堆是每個(gè)結(jié)點(diǎn)的值不大于他的父親結(jié)點(diǎn)的值;小根堆是每個(gè)結(jié)點(diǎn)的值不小于他的父親結(jié)點(diǎn)的值。本文將利用完全二叉樹(shù)創(chuàng)建大根堆和小根堆,感興趣的可以了解一下2022-08-08JVM調(diào)優(yōu)參數(shù)的設(shè)置
Java虛擬機(jī)的調(diào)優(yōu)是一個(gè)復(fù)雜而關(guān)鍵的任務(wù),可以通過(guò)多種參數(shù)來(lái)實(shí)現(xiàn),本文就來(lái)介紹一下JVM調(diào)優(yōu)參數(shù)的設(shè)置,具有一定的參考價(jià)值,感興趣的可以了解一下2024-03-03Eclipse下基于Java的OpenCV開(kāi)發(fā)環(huán)境配置教程
這篇文章主要為大家詳細(xì)介紹了Eclipse下基于Java的OpenCV開(kāi)發(fā)環(huán)境配置教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07