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類(lèi)實(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ù)端線程類(lèi) //繼承Thread類(lèi)的話,必須重寫(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-05Java基礎(chǔ)入門(mén)總結(jié)之序列化和反序列化
序列化是一種對(duì)象持久化的手段,普遍應(yīng)用在網(wǎng)絡(luò)傳輸、RMI等場(chǎng)景中,下面這篇文章主要給大家介紹了關(guān)于Java基礎(chǔ)入門(mén)總結(jié)之序列化和反序列化的相關(guān)資料,需要的朋友可以參考下2022-02-02java 用redisTemplate 的 Operations存取list集合操作
這篇文章主要介紹了java 用redisTemplate 的 Operations存取list集合操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08Java 回調(diào)機(jī)制(CallBack) 詳解及實(shí)例代碼
這篇文章主要介紹了 Java 回調(diào)機(jī)制(CallBack) 詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2017-02-02