Java--Socket通信(客戶(hù)端服務(wù)端雙向)
新建兩個(gè)工程,一個(gè)客戶(hù)端,一個(gè)服務(wù)端,先啟動(dòng)服務(wù)端再啟動(dòng)客戶(hù)端
兩個(gè)工程的讀寫(xiě)操作線(xiàn)程類(lèi)基本上完全相同
服務(wù)端:
import java.io.BufferedReader; import java.io.DataInputStream; import java.io.DataOutputStream; import java.io.IOException; import java.io.InputStreamReader; import java.net.ServerSocket; import java.net.Socket; public class Server { public static final int PORT = 8000;//監(jiān)聽(tīng)的端口號(hào) public static void main(String[] args) { Server server = new Server(); server.init(); } public void init() { ServerSocket serverSocket = null; try { serverSocket = new ServerSocket(PORT); while (true) { Socket client = serverSocket.accept(); //一個(gè)客戶(hù)端連接就開(kāi)戶(hù)兩個(gè)線(xiàn)程處理讀寫(xiě) new Thread(new ReadHandlerThread(client)).start(); new Thread(new WriteHandlerThread(client)).start(); } } catch (Exception e) { e.printStackTrace(); } finally{ try { if(serverSocket != null){ serverSocket.close(); } } catch (IOException e) { e.printStackTrace(); } } } } /* *處理讀操作的線(xiàn)程 */ class ReadHandlerThread implements Runnable{ private Socket client; public ReadHandlerThread(Socket client) { this.client = client; } @Override public void run() { DataInputStream dis = null; try{ while(true){ //讀取客戶(hù)端數(shù)據(jù) dis = new DataInputStream(client.getInputStream()); String reciver = dis.readUTF(); System.out.println("客戶(hù)端發(fā)過(guò)來(lái)的內(nèi)容:" + reciver); } }catch(Exception e){ e.printStackTrace(); }finally{ try { if(dis != null){ dis.close(); } if(client != null){ client = null; } } catch (IOException e) { e.printStackTrace(); } } } } /* * 處理寫(xiě)操作的線(xiàn)程 */ class WriteHandlerThread implements Runnable{ private Socket client; public WriteHandlerThread(Socket client) { this.client = client; } @Override public void run() { DataOutputStream dos = null; BufferedReader br = null; try{ while(true){ //向客戶(hù)端回復(fù)信息 dos = new DataOutputStream(client.getOutputStream()); System.out.print("請(qǐng)輸入:\t"); // 鍵盤(pán)錄入 br = new BufferedReader(new InputStreamReader(System.in)); String send = br.readLine(); //發(fā)送數(shù)據(jù) dos.writeUTF(send); } }catch(Exception e){ e.printStackTrace(); }finally{ try { if(dos != null){ dos.close(); } if(br != null){ br.close(); } if(client != null){ client = null; } } catch (IOException e) { e.printStackTrace(); } } } }
客戶(hù)端:
import java.io.BufferedReader; import java.io.DataInputStream; import java.io.DataOutputStream; import java.io.IOException; import java.io.InputStreamReader; import java.net.Socket; public class Client { public static final String IP = "localhost";//服務(wù)器地址 public static final int PORT = 8000;//服務(wù)器端口號(hào) public static void main(String[] args) { handler(); } private static void handler(){ try { //實(shí)例化一個(gè)Socket,并指定服務(wù)器地址和端口 Socket client = new Socket(IP, PORT); //開(kāi)啟兩個(gè)線(xiàn)程,一個(gè)負(fù)責(zé)讀,一個(gè)負(fù)責(zé)寫(xiě) new Thread(new ReadHandlerThread(client)).start(); new Thread(new WriteHandlerThread(client)).start(); } catch (Exception e) { e.printStackTrace(); } } } /* *處理讀操作的線(xiàn)程 */ class ReadHandlerThread implements Runnable{ private Socket client; public ReadHandlerThread(Socket client) { this.client = client; } @Override public void run() { DataInputStream dis = null; try { while(true){ //讀取服務(wù)器端數(shù)據(jù) dis = new DataInputStream(client.getInputStream()); String receive = dis.readUTF(); System.out.println("服務(wù)器端返回過(guò)來(lái)的是: " + receive); } } catch (IOException e) { e.printStackTrace(); } finally{ try { if(dis != null){ dis.close(); } if(client != null){ client = null; } } catch (IOException e) { e.printStackTrace(); } } } } /* * 處理寫(xiě)操作的線(xiàn)程 */ class WriteHandlerThread implements Runnable{ private Socket client; public WriteHandlerThread(Socket client) { this.client = client; } @Override public void run() { DataOutputStream dos = null; BufferedReader br = null; try { while(true){ //取得輸出流 dos = new DataOutputStream(client.getOutputStream()); System.out.print("請(qǐng)輸入: \t"); //鍵盤(pán)錄入 br = new BufferedReader(new InputStreamReader(System.in)); String send = br.readLine(); //發(fā)送數(shù)據(jù) dos.writeUTF(send); } } catch (IOException e) { e.printStackTrace(); } finally{ try{ if(dos != null){ dos.close(); } if(br != null){ br.close(); } if(client != null){ client = null; } }catch(Exception e){ e.printStackTrace(); } } } }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Java通過(guò)socket客戶(hù)端保持連接服務(wù)端實(shí)現(xiàn)代碼
- java客戶(hù)端線(xiàn)上Apollo服務(wù)端的實(shí)現(xiàn)
- Java基于socket實(shí)現(xiàn)的客戶(hù)端和服務(wù)端通信功能完整實(shí)例
- Java編程Socket實(shí)現(xiàn)多個(gè)客戶(hù)端連接同一個(gè)服務(wù)端代碼
- java實(shí)現(xiàn)socket客戶(hù)端連接服務(wù)端
- 簡(jiǎn)單的java socket客戶(hù)端和服務(wù)端示例
- java實(shí)現(xiàn)protocol傳輸?shù)目蛻?hù)端和服務(wù)端的示例代碼
相關(guān)文章
基于Jenkins搭建.NET FrameWork持續(xù)集成環(huán)境
這篇文章主要介紹了基于Jenkins搭建.NET FrameWork持續(xù)集成環(huán)境,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08利用Java的Struts框架實(shí)現(xiàn)電子郵件發(fā)送功能
這篇文章主要介紹了利用Java的Struts框架實(shí)現(xiàn)電子郵件發(fā)送功能,Struts框架是Java的SSH三大web開(kāi)發(fā)框架之一,需要的朋友可以參考下2015-12-12Dependency ‘XXX:‘ not found問(wèn)題的三步解決
這篇文章主要介紹了Dependency ‘XXX:‘ not found問(wèn)題的三步解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01java異步調(diào)用的4種實(shí)現(xiàn)方法
日常開(kāi)發(fā)中,會(huì)經(jīng)常遇到說(shuō),前臺(tái)調(diào)服務(wù),本文主要介紹了java異步調(diào)用的4種實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03maven父子工程多模塊統(tǒng)一管理版本號(hào)的解決方法
maven父子工程多模塊,每個(gè)模塊還都可以獨(dú)立存在,子模塊往往通常希望和父工程保持一樣的版本,如果每個(gè)工程單獨(dú)定義版本號(hào),后期變更打包也非常麻煩,,所以本文給大家介紹了maven父子工程多模塊如何管理統(tǒng)一的版本號(hào),需要的朋友可以參考下2024-09-09SpringCloud 搭建企業(yè)級(jí)開(kāi)發(fā)框架之實(shí)現(xiàn)多租戶(hù)多平臺(tái)短信通知服務(wù)(微服務(wù)實(shí)戰(zhàn))
這篇文章主要介紹了SpringCloud 搭建企業(yè)級(jí)開(kāi)發(fā)框架之實(shí)現(xiàn)多租戶(hù)多平臺(tái)短信通知服務(wù),系統(tǒng)可以支持多家云平臺(tái)提供的短信服務(wù)。這里以阿里云和騰訊云為例,集成短信通知服務(wù),需要的朋友可以參考下2021-11-11