Java基于socket服務(wù)實(shí)現(xiàn)UDP協(xié)議的方法
本文實(shí)例講述了Java基于socket服務(wù)實(shí)現(xiàn)UDP協(xié)議的方法。分享給大家供大家參考。具體如下:
示例1:
接收類:
package com.socket.demo;
import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
public class UDPReceiveDemo {
public static void main(String[] args) throws IOException{
System.out.println("接收端啟動(dòng)…………");
/*
2、建立UDP的socket的服務(wù),必須明確一個(gè)端口號(hào)
3、創(chuàng)建數(shù)據(jù)包,用于儲(chǔ)存接收到的數(shù)據(jù),方便用數(shù)據(jù)包對(duì)象的方法解析這些數(shù)據(jù)
4、使用DatagramSocket的receive方法將接收到的數(shù)據(jù)存儲(chǔ)到數(shù)據(jù)包中
5、通過數(shù)據(jù)包的方法解析數(shù)據(jù)包中的數(shù)據(jù)
5、關(guān)閉socket服務(wù)
*/
//udpsocket服務(wù),使用DatagramSocket對(duì)象
DatagramSocket ds=new DatagramSocket(10002);
//使用DatagramPacket將數(shù)據(jù)封裝到該對(duì)象中
byte[] buf=new byte[1024];
DatagramPacket dp=new DatagramPacket(buf, buf.length);
//通過udp的socket服務(wù)將數(shù)據(jù)包發(fā)送出去,通過send方法
ds.receive(dp);
//通過數(shù)據(jù)包的方法解析數(shù)據(jù)包中的數(shù)據(jù),比如,地址、端口、數(shù)據(jù)內(nèi)容等
String ip=dp.getAddress().getHostAddress();
//String name=dp.getAddress().getHostName();
int port=dp.getPort();
String text=new String(dp.getData(),0,dp.getLength());
//System.out.println("-----"+ip+"-----"+name+"-----"+port+"-----"+text);
System.out.println("-----"+ip+"----------"+port+"-----"+text);
//關(guān)閉資源
ds.close();
}
}
發(fā)送類:
package com.socket.demo;
import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.net.SocketException;
import java.net.UnknownHostException;
public class UDPSendDemo {
public static void main(String[] args) throws IOException{
System.out.println("發(fā)送端啟動(dòng)…………");
/*
* 1、創(chuàng)建udp傳輸?shù)陌l(fā)送端
2、建立UDP的socket的服務(wù)
3、將要發(fā)送的數(shù)據(jù)封裝到數(shù)據(jù)包中
4、通過udp的socket服務(wù)將數(shù)據(jù)包發(fā)送出去
5、關(guān)閉socket服務(wù)
*/
//udpsocket服務(wù),使用DatagramSocket對(duì)象
DatagramSocket ds=new DatagramSocket(8888);//監(jiān)聽端口
//將要發(fā)送的數(shù)據(jù)封裝到數(shù)據(jù)包中
String str="udp傳輸演示,go";
//使用DatagramPacket將數(shù)據(jù)封裝到該對(duì)象中
byte[] buf=str.getBytes();
DatagramPacket dp=
new DatagramPacket(buf, buf.length,InetAddress.getByName("192.168.1.100"),10002);
//通過udp的socket服務(wù)將數(shù)據(jù)包發(fā)送出去,通過send方法
ds.send(dp);
//關(guān)閉資源
ds.close();
}
}
示例2:
接收類:
package com.socket.demo;
import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
public class UDPReceiveDemo2 {
public static void main(String[] args) throws IOException{
System.out.println("接收端啟動(dòng)…………");
/*
2、建立UDP的socket的服務(wù),必須明確一個(gè)端口號(hào)
3、創(chuàng)建數(shù)據(jù)包,用于儲(chǔ)存接收到的數(shù)據(jù),方便用數(shù)據(jù)包對(duì)象的方法解析這些數(shù)據(jù)
4、使用DatagramSocket的receive方法將接收到的數(shù)據(jù)存儲(chǔ)到數(shù)據(jù)包中
5、通過數(shù)據(jù)包的方法解析數(shù)據(jù)包中的數(shù)據(jù)
5、關(guān)閉socket服務(wù)
*/
//udpsocket服務(wù),使用DatagramSocket對(duì)象
DatagramSocket ds=new DatagramSocket(10003);
while(true){
//使用DatagramPacket將數(shù)據(jù)封裝到該對(duì)象中
byte[] buf=new byte[1024];
DatagramPacket dp=new DatagramPacket(buf, buf.length);
//通過udp的socket服務(wù)將數(shù)據(jù)包發(fā)送出去,通過send方法
ds.receive(dp);//阻塞式的。
//通過數(shù)據(jù)包的方法解析數(shù)據(jù)包中的數(shù)據(jù),比如,地址、端口、數(shù)據(jù)內(nèi)容等
String ip=dp.getAddress().getHostAddress();
//String name=dp.getAddress().getHostName();
int port=dp.getPort();
String text=new String(dp.getData(),0,dp.getLength());
//System.out.println("-----"+ip+"-----"+name+"-----"+port+"-----"+text);
System.out.println("-----"+ip+"----------"+port+"-----"+text);
}
//關(guān)閉資源
//ds.close();
}
}
發(fā)送類:
package com.socket.demo;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
public class UDPSendDemo2 {
public static void main(String[] args) throws IOException{
System.out.println("發(fā)送端啟動(dòng)…………");
/*
* 1、創(chuàng)建udp傳輸?shù)陌l(fā)送端
2、建立UDP的socket的服務(wù)
3、將要發(fā)送的數(shù)據(jù)封裝到數(shù)據(jù)包中
4、通過udp的socket服務(wù)將數(shù)據(jù)包發(fā)送出去
5、關(guān)閉socket服務(wù)
*/
//udpsocket服務(wù),使用DatagramSocket對(duì)象
DatagramSocket ds=new DatagramSocket(9999);//監(jiān)聽端口
//將要發(fā)送的數(shù)據(jù)封裝到數(shù)據(jù)包中
//String str="udp傳輸演示,go";
BufferedReader bufr=new BufferedReader(new InputStreamReader(System.in));//鍵盤輸入
String line=null;
//使用DatagramPacket將數(shù)據(jù)封裝到該對(duì)象中
while((line=bufr.readLine())!=null){
byte[] buf=line.getBytes();//
DatagramPacket dp=
new DatagramPacket(buf, buf.length,InetAddress.getByName("192.168.1.100"),10003);
//通過udp的socket服務(wù)將數(shù)據(jù)包發(fā)送出去,通過send方法
ds.send(dp);
if("886".equals(line)){
break;
}
}
//關(guān)閉資源
ds.close();
}
}
運(yùn)行效果圖如下:
接收:

發(fā)送:

希望本文所述對(duì)大家的java程序設(shè)計(jì)有所幫助。
相關(guān)文章
Spring AI與DeepSeek實(shí)戰(zhàn)一之快速打造智能對(duì)話應(yīng)用
本文詳細(xì)介紹了如何通過SpringAI框架集成DeepSeek大模型,實(shí)現(xiàn)普通對(duì)話和流式對(duì)話功能,步驟包括申請(qǐng)API-KEY、項(xiàng)目搭建、配置API-KEY、創(chuàng)建ChatClient對(duì)象、創(chuàng)建對(duì)話接口、切換模型、使用prompt模板、流式對(duì)話等,感興趣的朋友一起看看吧2025-03-03
JPA中@CreatedDate和@LastModifiedDate的使用方式
2023-11-11
Spring Cloud 配置中心內(nèi)容加密的配置方法
這篇文章主要介紹了Spring Cloud 配置中心內(nèi)容加密的配置方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-06-06
spring?boot項(xiàng)目中集成rocketmq詳細(xì)步驟
這篇文章主要給大家介紹了關(guān)于spring?boot項(xiàng)目中集成rocketmq的相關(guān)資料,springboot集成rocketmq的方法非常簡單,文中直接上代碼,需要的朋友可以參考下2023-09-09
Spring,hibernate,struts經(jīng)典面試筆試題(含答案)
這篇文章主要介紹了Spring,hibernate,struts經(jīng)典面試筆試題極其參考含答案,涉及SSH基本概念,原理與使用技巧,需要的朋友可以參考下2016-03-03
Java使用Jdbc連接Oracle執(zhí)行簡單查詢操作示例
這篇文章主要介紹了Java使用Jdbc連接Oracle執(zhí)行簡單查詢操作,結(jié)合實(shí)例形式詳細(xì)分析了java基于jdbc實(shí)現(xiàn)Oracle數(shù)據(jù)庫的連接與查詢相關(guān)操作技巧,需要的朋友可以參考下2019-09-09

