Java網(wǎng)絡(luò)編程實(shí)例——簡(jiǎn)單模擬在線聊天
1、前提知識(shí)
需要知道簡(jiǎn)單的IO流操作,以及簡(jiǎn)單的UDP發(fā)送數(shù)據(jù)包的原理。
需要用到的類:DatagramSocket、DatagramPacket
UDP數(shù)據(jù)包基于DatagramSocket發(fā)送和接收,DatagramPacket用于封裝數(shù)據(jù)包
看下案例:
客戶端發(fā)送消息:
正常情況下從控制臺(tái)讀信息,封裝到DatagramPacket之中,再由DatagramSocket的send方法發(fā)出
讀取到bye的時(shí)候退出聊天
public class UdpOnlineClient { public static void main(String[] args) throws IOException { DatagramSocket socket = new DatagramSocket(10000); BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(System.in)); while (true) { String data = bufferedReader.readLine(); byte[] datas = data.getBytes(); DatagramPacket packet = new DatagramPacket(datas, 0, datas.length, new InetSocketAddress("localhost", 9999)); socket.send(packet); if (data.equals("bye")){ break; } } socket.close(); } }
服務(wù)端接收消息:
DatagramSocket的receive方法接收客戶端發(fā)送的消息,打印到控制臺(tái),如果信息是bye則退出聊天
public class UdpOnlineServer { public static void main(String[] args) throws IOException { DatagramSocket socket = new DatagramSocket(9999); while (true){ byte[] buffer = new byte[1024]; DatagramPacket packet = new DatagramPacket(buffer, 0, buffer.length); socket.receive(packet); String msg = new String(packet.getData(), 0, packet.getLength()); System.out.println(msg); if(msg.equals("bye")){ break; } } socket.close(); } }
試驗(yàn):正常開啟客戶端和服務(wù)端后:
客戶端發(fā)送消息:
服務(wù)端接收到信息即成功:
有了這個(gè)思路,我們只需要把發(fā)送和接收封裝成發(fā)送類和接收類,使用多線程即可實(shí)現(xiàn)聊天了
2、實(shí)現(xiàn)思路:
創(chuàng)建UDP發(fā)送實(shí)現(xiàn)類TaskSend、UDP接收實(shí)現(xiàn)類TaskReceive,以及模擬多線程通信的通信類ChatThread1、ChatThread2
UDP發(fā)送實(shí)現(xiàn)類TaskSend:
public class TaskSend implements Runnable{ private String sendIP; //自己的服務(wù)端口 private int ownPort; private int sendPort; //讀取控制臺(tái)輸入流 private BufferedReader bufferedReader; private DatagramSocket socket; public TaskSend(String sendIP, int ownPort, int sendPort) { this.sendIP = sendIP; this.sendPort = sendPort; try { socket = new DatagramSocket(ownPort); bufferedReader = new BufferedReader(new InputStreamReader(System.in)); } catch (SocketException e) { e.printStackTrace(); } finally { } } //發(fā)送消息 public void run() { while (true) { try { String data = bufferedReader.readLine(); //打印自己的消息 System.out.println("我:"+data); byte[] datas = data.getBytes(); DatagramPacket packet = new DatagramPacket(datas, 0, datas.length,new InetSocketAddress(sendIP,sendPort)); socket.send(packet); if (data.equals("bye")) { break; } } catch (IOException e) { e.printStackTrace(); } finally { } } socket.close(); } }
UDP接收實(shí)現(xiàn)類TaskReceive:
public class TaskReceive implements Runnable{ private int ownPort; //發(fā)送信息的人 private String msgOwner; private DatagramSocket socket; public TaskReceive(int ownPort, String msgOwner) { this.msgOwner = msgOwner; try { socket = new DatagramSocket(ownPort); } catch (SocketException e) { e.printStackTrace(); } finally { } } //接收消息 public void run() { while (true) { try { byte[] buffer = new byte[1024]; DatagramPacket packet = new DatagramPacket(buffer, 0, buffer.length); socket.receive(packet); String msg = new String(packet.getData(), 0, packet.getLength()); System.out.println(msgOwner+":"+msg); if (msg.equals("bye")) { break; } } catch (IOException e) { e.printStackTrace(); } finally { } } socket.close(); } }
之后使用兩個(gè)通信類開啟多線程模擬一下:
模擬老師
public class ChatThread1 { public static void main(String[] args) { new Thread(new TaskSend("localhost",9999,10000)).start(); new Thread(new TaskReceive(9998,"老師")).start(); } }
模擬學(xué)生
public class ChatThread2 { public static void main(String[] args) { new Thread(new TaskReceive(9999,"學(xué)生")).start(); new Thread(new TaskSend("localhost",9998,10001)).start(); } }
實(shí)例:
學(xué)生
老師
到此簡(jiǎn)單的在線聊天功能就完成了,可以鞏固一下之前學(xué)習(xí)的網(wǎng)絡(luò)知識(shí)
以上就是Java網(wǎng)絡(luò)編程實(shí)例——簡(jiǎn)單模擬在線聊天的詳細(xì)內(nèi)容,更多關(guān)于Java 模擬在線聊天的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- java實(shí)現(xiàn)在線聊天系統(tǒng)
- Java實(shí)現(xiàn)在線聊天室(層層遞進(jìn))
- Java實(shí)現(xiàn)在線聊天功能
- Java網(wǎng)絡(luò)編程UDP實(shí)現(xiàn)多線程在線聊天
- Java使用TCP實(shí)現(xiàn)在線聊天的示例代碼
- Java GUI編程實(shí)現(xiàn)在線聊天室
- Java中使用websocket實(shí)現(xiàn)在線聊天功能
- java Socket實(shí)現(xiàn)網(wǎng)頁(yè)版在線聊天
- 基于Java Socket實(shí)現(xiàn)一個(gè)簡(jiǎn)易在線聊天功能(一)
- java基于UDP實(shí)現(xiàn)在線聊天功能
相關(guān)文章
java實(shí)體類轉(zhuǎn)成map的實(shí)現(xiàn)
這篇文章主要介紹了java實(shí)體類轉(zhuǎn)成map的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06詳解elasticsearch實(shí)現(xiàn)基于拼音搜索
這篇文章主要為大家介紹了詳解elasticsearch實(shí)現(xiàn)基于拼音搜索示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01Java中弱引用和軟引用的區(qū)別以及虛引用和強(qiáng)引用介紹
很早Java API就添加了弱引用(WeakReference)和軟引用(SoftReference),但并不是所有的程序員都熟悉這兩個(gè)概念2014-04-04本地安裝MinIO分布式對(duì)象存儲(chǔ)服務(wù)器的詳細(xì)步驟
本地安裝MinIO非常簡(jiǎn)單,MinIO提供了獨(dú)立的二進(jìn)制文件,無需額外的依賴,本文介紹如何在本地安裝MinIO分布式對(duì)象存儲(chǔ)服務(wù)器,感興趣的朋友一起看看吧2024-01-01MybatisPlus關(guān)聯(lián)查詢的完美實(shí)現(xiàn)方案
我們?cè)陧?xiàng)目開發(fā)的時(shí)候,難免會(huì)遇到連表查詢的操作,所以下面這篇文章主要給大家介紹了關(guān)于MybatisPlus關(guān)聯(lián)查詢的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2021-12-12Java8如何利用Lambda快速生成map、多層嵌套map
這篇文章主要介紹了Java8如何利用Lambda快速生成map、多層嵌套map問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09解決springboot項(xiàng)目上傳文件出現(xiàn)臨時(shí)文件目錄為空的問題
這篇文章主要介紹了解決springboot項(xiàng)目上傳文件出現(xiàn)臨時(shí)文件目錄為空的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-09-09簡(jiǎn)述springboot及springboot cloud環(huán)境搭建
這篇文章主要介紹了簡(jiǎn)述springboot及springboot cloud環(huán)境搭建的方法,包括spring boot 基礎(chǔ)應(yīng)用環(huán)境搭建,需要的朋友可以參考下2017-07-07