Socket最簡單的客戶端與服務端通訊-Java
導讀 | 因為最近專案中要接入某通訊協議介面,基於TCP/IP的socket介面。於是就在本地弄一個最簡單的Socket 通訊僅供學習。話不多說,直接開擺 |
socket是在應用層和傳輸層之間的一個抽象層,它把TCP/IP層複雜的操作抽象為幾個簡單的介面供應用層呼叫以實現程式在網路中通訊。socket如何實現通訊
客戶端程式碼
package test; import java.io.*; import java.net.Inet4Address; import java.net.InetSocketAddress; import java.net.Socket; public class Client { //java基礎類方法的入口 public static void main(String[] args)throws IOException { Socket socket=new Socket(); //讀取流超時的時間設定為3000 socket.setSoTimeout(3000); //連線本地,埠2000;超時時間3000ms socket.connect(new InetSocketAddress(Inet4Address.getLocalHost(), 2000),3000); System.out.println("發起伺服器連線---------"); System.out.println("客戶端資訊:"+socket.getLocalAddress()+" P:"+socket.getLocalPort());//列印本地伺服器地址和本地埠號 System.out.println("服務端資訊:"+socket.getInetAddress()+" P:"+socket.getPort()); try{ //傳送接收資料 todo(socket); }catch (Exception e){ System.out.println("出現異常關閉啦"); } //釋放資源 socket.close(); System.out.println("再見,客戶端已退出"); } //傳送資料的方法 private static void todo(Socket client) throws IOException{ //構建鍵盤輸入流 InputStream in=System.in; //把鍵盤輸入流轉換為BufferedReader BufferedReader input=new BufferedReader(new InputStreamReader(in,"UTF-8")); //得到Socket輸出流(Client要傳送出去給伺服器的資訊),並轉換為列印流 OutputStream outputStream = client.getOutputStream(); PrintStream socketPrintStream=new PrintStream(outputStream); //得到Socket輸入流(Server回覆傳入Client的資訊),並轉換為BufferedReader InputStream inputStream = client.getInputStream(); BufferedReader socketBufferedReader=new BufferedReader(new InputStreamReader(inputStream,"UTF-8")); //判斷Server是否想要退出,回覆“bye”時是他想要結束對話 boolean flag=true; do { //鍵盤讀取一行 String str = input.readLine(); //傳送到伺服器,(通俗就是顯示在輸入處,在鍵盤上輸入什麼,螢幕顯示什麼) //String str = "003099999920220614100000M1S1C0x0a"; socketPrintStream.println(str); //從伺服器讀取一行,即Server傳入回覆給Client的資訊 String echo = socketBufferedReader.readLine(); if("bye".equalsIgnoreCase(echo)){ flag=false; } else{ //列印到螢幕上,Server回覆什麼就顯示什麼 System.out.println("客戶端回覆:"+echo); } }while(flag); //資源釋放,關閉對於socket資源 socketPrintStream.close(); socketBufferedReader.close(); } }
服務端程式碼
package test; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.io.PrintStream; import java.net.ServerSocket; import java.net.Socket; public class Server { public static void main(String[] args)throws IOException { ServerSocket server=new ServerSocket(2000); System.out.println("伺服器準備就緒----------"); System.out.println("伺服器資訊:"+server.getInetAddress()+" P:"+server.getLocalPort()); //等待多個客戶端連線,迴圈非同步執行緒 for(;;) { //得到客戶端 Socket client = server.accept(); //客戶端構建非同步執行緒 ClientHandler clientHandler = new ClientHandler(client); //啟動執行緒 clientHandler.start(); } } /** * 客戶端訊息處理 */ //多個客戶端需要做非同步操作,建立非同步處理類 private static class ClientHandler extends Thread{//執行緒 private Socket socket;//代表當前的一個連線 private boolean flag=true; ClientHandler(Socket socket){ this.socket=socket; }//構造方法 //一旦Thead啟動起來,就會執行run方法,代表執行緒啟動的部分 @Override public void run(){ super.run(); //列印客戶端的資訊 System.out.println("新客戶端發起連線:"+socket.getInetAddress()+" P:"+socket.getPort()); //在傳送過程中會觸發一個IO過程,所以需要捕獲異常 try { //得到列印流,用於資料輸出,伺服器回送資料使用,即在螢幕上顯示Server要回復Client的資訊 PrintStream socketOutput=new PrintStream(socket.getOutputStream()); //得到輸入流,用於接收資料,得到Client回覆伺服器的資訊 BufferedReader sockeInput=new BufferedReader(new InputStreamReader(socket.getInputStream(),"UTF-8")); do { //客戶端回覆一條資料 String str = sockeInput.readLine(); if("bye".equalsIgnoreCase(str)){ flag=false; //回送 socketOutput.println("bye"); }else{ //列印到螢幕,並回送資料長度 System.out.println(str); socketOutput.println("Server回答說:" +str.length()); } }while(flag); sockeInput.close(); socketOutput.close(); }catch (Exception e){ //觸發異常時列印一個異常資訊 System.out.println("連線異常斷開!!!"); }finally { //連線關閉 try { socket.close(); } catch (IOException e) { e.printStackTrace(); } } System.out.println("再見,客戶端退出:"+socket.getInetAddress()+" P:"+socket.getPort()); } } }
然後先執行服務端類Server.java,然後再執行Client.java
在客戶端控制檯輸入任意文字,按下Enter鍵即可。
原文來自:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69955379/viewspace-2903545/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 實現客戶端與服務端的HTTP通訊客戶端服務端HTTP
- 基於node的tcp客戶端和服務端的簡單通訊TCP客戶端服務端
- TCP通訊客戶端和服務端簡單程式碼實現TCP客戶端服務端
- TCP協議服務端和客戶端的連線與通訊TCP協議服務端客戶端
- HarmonyOS IPC Kit進階:客戶端與服務端的基礎通訊客戶端服務端
- php原生socket實現客戶端與服務端資料傳輸PHP客戶端服務端
- 如何用Java Socket實現一個簡單的Redis客戶端JavaRedis客戶端
- 服務端,客戶端服務端客戶端
- 客戶端,服務端客戶端服務端
- java socket 通訊socketServer 服務端多執行緒JavaServer服務端執行緒
- SHA-256加密簡單例項(客戶端、服務端)加密單例客戶端服務端
- Linux下簡單的ACE socket客戶端和伺服器端Linux客戶端伺服器
- Java的oauth2.0 服務端與客戶端的實現JavaOAuth服務端客戶端
- 一段最簡單的使用socket.io進行伺服器和客戶端通訊的例子程式碼伺服器客戶端
- Python socket的客戶端Python客戶端
- C/S(socket、執行緒 實現多個客戶端、伺服器端簡易通訊)執行緒客戶端伺服器
- rsync備份【基於客戶端與服務端】客戶端服務端
- Windows10 VS2017 C++ Server Socket簡單伺服器端與客戶端WindowsC++Server伺服器客戶端
- 利用tirpc庫實現簡單的客戶端和服務端RPC客戶端服務端
- python實現兩臺不同主機之間進行通訊(客戶端和服務端)——SocketPython客戶端服務端
- socket實現服務端多執行緒,客戶端重複輸入服務端執行緒客戶端
- 服務端渲染和客戶端渲染服務端客戶端
- Java與WCF互動(一):Java客戶端呼叫WCF服務 (轉)Java客戶端
- Java服務端和客戶端開發輔助工具UtilsJava服務端客戶端
- JAVA通訊(一)——輸入資料到客戶端Java客戶端
- Laravel後臺作為客戶端,socket.io作為服務端,App或其他作為另一個客戶端Laravel客戶端服務端APP
- python建立tcp服務端和客戶端PythonTCP服務端客戶端
- Java的Socket通訊簡單例項Java單例
- Go gRPC 系列二:一元客戶端與服務端GoRPC客戶端服務端
- macOS 自帶的ftp服務端&vnc客戶端MacFTP服務端VNC客戶端
- c#實現最簡單的socket通訊C#
- 簡單的Socket通訊
- OSSEC服務端配置客戶端批次部署方案服務端客戶端
- golang實現tcp客戶端服務端程式GolangTCP客戶端服務端
- Redis:我是如何與客戶端進行通訊的Redis客戶端
- 客戶端與服務端的三次握手與四次揮手客戶端服務端
- Kubernetes 實戰 —— 05. 服務:讓客戶端發現 pod 並與之通訊(下)客戶端
- 使用Apollo Server搭建GraphQL的服務端和客戶端Server服務端客戶端