Java實(shí)現(xiàn)TCP/IP協(xié)議的收發(fā)數(shù)據(jù)(服務(wù)端)代碼實(shí)例
這篇文章主要介紹了Java實(shí)現(xiàn)TCP/IP協(xié)議的收發(fā)數(shù)據(jù)(服務(wù)端)代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
功能如下:

注:
只有服務(wù)端,沒(méi)有客戶端,測(cè)試時(shí)采用第三方軟件作為客戶端的。
收發(fā)數(shù)據(jù)目前能正常收發(fā)數(shù)據(jù),只是中文的會(huì)變成亂碼顯示。
采用Thread類實(shí)現(xiàn)一個(gè)收發(fā)數(shù)據(jù)的線程。
服務(wù)端代碼:
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.ServerSocket;
import java.net.Socket;
public class Server {
//監(jiān)聽(tīng)端口
private static final int PORT = 60020;
public static void main(String[] args) throws IOException {
ServerSocket serverSocket = null;
Socket socket = null;
try {
//建立服務(wù)器的Socket,并設(shè)定一個(gè)監(jiān)聽(tīng)的端口PORT
serverSocket = new ServerSocket(PORT);
//由于需要進(jìn)行循環(huán)監(jiān)聽(tīng),因此獲取消息的操作應(yīng)放在一個(gè)while大循環(huán)中
while(true){
try {
//建立跟客戶端的連接
socket = serverSocket.accept();
} catch (Exception e) {
System.out.println("建立與客戶端的連接出現(xiàn)異常");
e.printStackTrace();
}
ServerThread thread = new ServerThread(socket);
thread.start();
}
} catch (Exception e) {
System.out.println("端口被占用");
e.printStackTrace();
}
finally {
serverSocket.close();
}
}
}
//服務(wù)端線程類
//繼承Thread類的話,必須重寫(xiě)run方法,在run方法中定義需要執(zhí)行的任務(wù)。
class ServerThread extends Thread {
private Socket socket ;
InputStream inputStream;
OutputStream outputStream;
public ServerThread(Socket socket){
this.socket=socket;
}
public void run(){
try {
while (true){
//接收客戶端的消息并打印
System.out.println(socket);
inputStream=socket.getInputStream();
byte[] bytes = new byte[1024];
inputStream.read(bytes);
String string = new String(bytes);
System.out.println(string);
//向客戶端發(fā)送消息
outputStream = socket.getOutputStream();
outputStream.write("OK".getBytes());
System.out.println("OK");
}
} catch (Exception e) {
System.out.println("客戶端主動(dòng)斷開(kāi)連接了");
//e.printStackTrace();
}
//操作結(jié)束,關(guān)閉socket
try{
socket.close();
}catch(IOException e){
System.out.println("關(guān)閉連接出現(xiàn)異常");
e.printStackTrace();
}
}
}
先開(kāi)啟服務(wù)端,再開(kāi)啟客戶端,進(jìn)行操作。
客戶端:
(端口號(hào)選擇“TCPClient”,遠(yuǎn)程填寫(xiě)IP地址和程序里設(shè)定好的端口“60020”,本地選擇自己電腦的IP地址)

服務(wù)端:

注:
串口調(diào)試工具下載地址
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
java使用ArrayList遍歷及效率比較實(shí)例分析
這篇文章主要介紹了java使用ArrayList遍歷及效率比較,實(shí)例分析了ArrayList遍歷的方法與使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07
一口氣說(shuō)出Java 6種延時(shí)隊(duì)列的實(shí)現(xiàn)方法(面試官也得服)
這篇文章主要介紹了一口氣說(shuō)出Java 6種延時(shí)隊(duì)列的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05
Java基礎(chǔ)入門(mén)總結(jié)之序列化和反序列化
序列化是一種對(duì)象持久化的手段,普遍應(yīng)用在網(wǎng)絡(luò)傳輸、RMI等場(chǎng)景中,下面這篇文章主要給大家介紹了關(guān)于Java基礎(chǔ)入門(mén)總結(jié)之序列化和反序列化的相關(guān)資料,需要的朋友可以參考下2022-02-02
java 用redisTemplate 的 Operations存取list集合操作
這篇文章主要介紹了java 用redisTemplate 的 Operations存取list集合操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08
Java 回調(diào)機(jī)制(CallBack) 詳解及實(shí)例代碼
這篇文章主要介紹了 Java 回調(diào)機(jī)制(CallBack) 詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2017-02-02

