java —— 网络编程(UDP)

一、InetAddress 类

java 复制代码
InetAddress address1=InetAddress.getLocalHost();

该命令用于获取本机主机信息,返回主机名与 IP 地址,不过如果本机有多个网卡的话,返回的 IP 地址并不一定是目前正在联网的那个。

java 复制代码
InetAddress address2=InetAddress.getByName("DESKTOP-MINYU");
InetAddress address2=InetAddress.getByName("192.168.0.106");

该命令的参数可以是主机名,也可以是 IP 地址。当参数是主机名时,如果是本机主机名,则效果与**InetAddress.getLocalHost()**相同,也就是说返回的主机信息中的 IP 地址不一定是我们想要的。当参数是 IP 地址时,返回的就是输入的 IP 地址。

二、DatagramSocket 类

采用 UDP 通信的类为 DatagramSocket 类,其特点是事先不需要建立连接,发出去的数据对方能收到就收到,收不到拉倒。

在编写代码的时候需要用到 DatagramPacket 类,主要作用是对数据进行打包,然后交由 DatagramSocket 进行发送或接收。

发送端示例:

java 复制代码
public static void main(String args[])
{
    DatagramSocket ds=new DatagramSocket();
    //建立 Socket 对象,没有参数表明可以使用本机的任何端口进行发送。

    String x="hello";
    byte[] bytes=x.getBytes();
    InetAddress address=InetAddress.getByName("192.168.0.106");
    int port=10086;

    DatagramPacket dp=new DatagramPacket(bytes,bytes.length,address,port);
    //打包数据,对方IP是192.168.0.106,对方端口号是10086.

    ds.send(dp);
    //发送数据

    ds.close();
    //关闭资源
}

接收端示例:

java 复制代码
public static void main(String args[])
{
    DatagramSocket ds=new DatagramSocket(10086);
    //建立 Socket 对象,用于接收本机10086端口的数据。

    byte[] bytes=new byte[1024];
    DatagramPacket dp=new DatagramPacket(bytes,bytes.length);
    //打包数据,将后续接收到的数据打包进bytes字节数组里。

    ds.receive(dp);
    //接收数据

    byte[] x=dp.getData();
    int length=dp.getLength();
    //解析数据

    System.out.println(new String(x,0,length));
}

三、MulticastSocket 类

该类用于组播,替换单播的 DatagramSocket 类。

组播地址范围:224.0.0.0~224.0.0.255

发送端示例:

java 复制代码
public static void main(String args[])
{
    MulticastSocket ms=new MulticastSocket();
    //建立 Socket 对象,没有参数表明可以使用本机的任何端口进行发送。

    String x="hello";
    byte[] bytes=x.getBytes();
    InetAddress address=InetAddress.getByName("224.0.0.1");
    int port=10086;

    DatagramPacket dp=new DatagramPacket(bytes,bytes.length,address,port);
    //打包数据,组播IP是192.168.0.106,对方端口号是10086.

    ms.send(dp);
    //发送数据

    ms.close();
    //关闭资源
}

接收端示例:

java 复制代码
public static void main(String args[])
{
    MulticastSocket ms=new MulticastSocket(10086);
    //建立 Socket 对象,用于接收本机10086端口的数据。

    InetAddress address=InetAddress.getByName("224.0.0.1");
    ms.joinGroup(address);
    //将本机套接字加入组播地址

    byte[] bytes=new byte[1024];
    DatagramPacket dp=new DatagramPacket(bytes,bytes.length);
    //打包数据,将后续接收到的数据打包进bytes字节数组里。

    ms.receive(dp);
    //接收数据

    byte[] x=dp.getData();
    int length=dp.getLength();
    //解析数据

    System.out.println(new String(x,0,length));
}

四、广播

广播的代码实现与单播基本一样,只需要将地址改为 255.255.255.255 即表明向局域网内所有主机发送数据。

相关推荐
Java后端的Ai之路2 分钟前
【Spring全家桶】-一文弄懂Spring Cloud Gateway
java·后端·spring cloud·gateway
devmoon3 分钟前
在 Polkadot Runtime 中添加多个 Pallet 实例实战指南
java·开发语言·数据库·web3·区块链·波卡
野犬寒鸦7 分钟前
从零起步学习并发编程 || 第七章:ThreadLocal深层解析及常见问题解决方案
java·服务器·开发语言·jvm·后端·学习
云姜.11 分钟前
java抽象类和接口
java·开发语言
带刺的坐椅11 分钟前
Claude Code Skills,Google A2A Skills,Solon AI Skills 有什么区别?
java·ai·solon·a2a·claudecode·skills
心.c16 分钟前
TCP协议深入解析
网络·网络协议·tcp/ip
摇滚侠20 分钟前
HTTP 404 - No response body available
网络·网络协议·http
爱学英语的程序员23 分钟前
面试官:你了解过哪些数据库?
java·数据库·spring boot·sql·mysql·mybatis
全栈工程师修炼指南25 分钟前
Nginx | stream content 阶段:TCP 协议四层反向代理浅析与实践
运维·网络·网络协议·tcp/ip·nginx
Trouvaille ~33 分钟前
【Linux】应用层协议设计实战(一):自定义协议与网络计算器
linux·运维·服务器·网络·c++·http·应用层协议