Java基于TCP協(xié)議socket網(wǎng)絡(luò)編程的文件傳送的實(shí)現(xiàn)
先了解一下socket基本概念
socket也叫套接字:
是指在網(wǎng)路中不同主機(jī)上的應(yīng)用進(jìn)程之間,進(jìn)行雙向通信的端點(diǎn)的抽象。
簡單理解就是:
兩個主機(jī)之間要通信,就需要知道彼此的ip,端口號等信息,而一臺主機(jī)這些信息的集合:
就可以理解為一個端點(diǎn),即為套接字
雙方通過套接字作為一種坐標(biāo),建立信息通道,形成連接(兩點(diǎn)連接一條直線)
簡單理解了套接字的概念后,來看看如何通過java socket編程來實(shí)現(xiàn)
兩臺主機(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對象 創(chuàng)建socket連接
Socket socket = new Socket(InetAddress.getByName("127.0.0.1"), 9000);
//2,創(chuàng)建一個字節(jié)輸出流
OutputStream os = socket.getOutputStream();
//3.字節(jié)文件輸入流 讀取文件
//避免出錯 寫需要發(fā)送文件的絕對路徑
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)行一個非空判斷再關(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對象 創(chuàng)建接收端套接字
ServerSocket serverSocket=null;
//套接字
Socket socket=null;
//字節(jié)輸入流
InputStream in=null;
//默認(rèn)參數(shù)定義端口號 發(fā)送方依據(jù)這個端口號發(fā)送
serverSocket=new ServerSocket(9000);
socket = serverSocket.accept();
//socket對象 獲取輸入流,拿到文件
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)行一個非空判斷再關(guān)閉
fos.close();
serverSocket.close();
socket.close();
in.close();
}
}
測試方法:
以上代碼可直接粘貼測試
1、先運(yùn)行接收者等待接受,
2、再運(yùn)行發(fā)送者,
3、等待接收者向發(fā)送者響應(yīng): 我是文件接收者:我已成功接受;
4、接收者指定接受目錄下、查看接收文件存在即為接收成功!
總結(jié):
這個demo實(shí)現(xiàn)并不是很難,主要考驗(yàn)了我們對于io流的熟練程度
到此這篇關(guān)于Java基于TCP協(xié)議socket網(wǎng)絡(luò)編程的文件傳送的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Java socket文件傳送內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java中Map如何根據(jù)key的大小進(jìn)行排序詳解
這篇文章主要給大家介紹了關(guān)于java中Map如何根據(jù)key的大小進(jìn)行排序的相關(guān)資料,有時候我們業(yè)務(wù)上需要對map里面的值按照key的大小來進(jìn)行排序的時候我們就可以利用如下方法來進(jìn)行排序了,需要的朋友可以參考下2023-09-09
java連接mysql數(shù)據(jù)庫詳細(xì)步驟解析
以下是對java連接mysql數(shù)據(jù)庫的具體詳細(xì)步驟進(jìn)行了分析介紹,需要的朋友可以過來參考下2013-08-08
Springboot遷移到Micronaut實(shí)現(xiàn)過程詳解
這篇文章主要為大家?介紹了Springboot遷移到Micronaut實(shí)現(xiàn)過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05
JVM調(diào)優(yōu)參數(shù)的設(shè)置
Java虛擬機(jī)的調(diào)優(yōu)是一個復(fù)雜而關(guān)鍵的任務(wù),可以通過多種參數(shù)來實(shí)現(xiàn),本文就來介紹一下JVM調(diào)優(yōu)參數(shù)的設(shè)置,具有一定的參考價值,感興趣的可以了解一下2024-03-03
Eclipse下基于Java的OpenCV開發(fā)環(huán)境配置教程
這篇文章主要為大家詳細(xì)介紹了Eclipse下基于Java的OpenCV開發(fā)環(huán)境配置教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-07-07

