Java基于TCP協(xié)議socket網(wǎng)絡(luò)編程的文件傳送的實(shí)現(xiàn)
先了解一下socket基本概念
socket也叫套接字:
是指在網(wǎng)路中不同主機(jī)上的應(yīng)用進(jìn)程之間,進(jìn)行雙向通信的端點(diǎn)的抽象。
簡單理解就是:
兩個(gè)主機(jī)之間要通信,就需要知道彼此的ip,端口號(hào)等信息,而一臺(tái)主機(jī)這些信息的集合:
就可以理解為一個(gè)端點(diǎn),即為套接字
雙方通過套接字作為一種坐標(biāo),建立信息通道,形成連接(兩點(diǎn)連接一條直線)
簡單理解了套接字的概念后,來看看如何通過java socket編程來實(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.通過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() 否則影響接下來代碼執(zhí)行 socket.shutdownOutput(); //確定服務(wù)器接受完畢,斷開連接 //獲取接收方響應(yīng)回來的 接受完畢! 響應(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í)慣 這部分寫的簡單 //一般建議先進(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 { //通過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ā)送過來的 文件通過文件字節(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í)慣 這部分寫的簡單 //一般建議先進(jìn)行一個(gè)非空判斷再關(guān)閉 fos.close(); serverSocket.close(); socket.close(); in.close(); } }
測試方法:
以上代碼可直接粘貼測試
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的大小來進(jìn)行排序的時(shí)候我們就可以利用如下方法來進(jìn)行排序了,需要的朋友可以參考下2023-09-09java連接mysql數(shù)據(jù)庫詳細(xì)步驟解析
以下是對(duì)java連接mysql數(shù)據(jù)庫的具體詳細(xì)步驟進(jìn)行了分析介紹,需要的朋友可以過來參考下2013-08-08Springboot遷移到Micronaut實(shí)現(xiàn)過程詳解
這篇文章主要為大家?介紹了Springboot遷移到Micronaut實(shí)現(xiàn)過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05JVM調(diào)優(yōu)參數(shù)的設(shè)置
Java虛擬機(jī)的調(diào)優(yōu)是一個(gè)復(fù)雜而關(guān)鍵的任務(wù),可以通過多種參數(shù)來實(shí)現(xiàn),本文就來介紹一下JVM調(diào)優(yōu)參數(shù)的設(shè)置,具有一定的參考價(jià)值,感興趣的可以了解一下2024-03-03Eclipse下基于Java的OpenCV開發(fā)環(huán)境配置教程
這篇文章主要為大家詳細(xì)介紹了Eclipse下基于Java的OpenCV開發(fā)環(huán)境配置教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07