Java重修笔记 UDP 网络通信

UDP 网络通信原理
  1. 类 DatagramSocket 和 DatagramPacket [数据包/数据报] 实现了基于 UDP协议网络程序。

  2. UDP 数据报通过数据报套接字 DatagramSocket 发送和接收,系统不保证UDP数据报一定能够安全送到目的地,也不能确定什么时候可以抵达,所以 UDP 是不可靠的

  3. DatagramPacket 对象封装了 UDP 数据报,在数据报中包含了发送端的 IP 地址和端口号以及接收端的 IP 地址和端口号。

  4. UDP 协议中每个数据报都给出了完整的地址信息,因此无须建立发送方和接收方的连接

UDP 网络通信实现过程
  1. 核心的两个类/对象DatagramSocket与DatagramPacket

  2. 建立发送端,接收端(没有服务端和客户端概念)

  3. 发送数据前,建立数据包/报DatagramPacket对象

  4. 调用DatagramSocket的发送、接收方法

  5. 关闭DatagramSocket

java 复制代码
public class UDPReceiverA {
    public static void main(String[] args) throws IOException {
        // 创建一个 DatagramSocket 对象, 准备在端口 9999 接受数据
        DatagramSocket socket = new DatagramSocket(9999);
        // 创建一个 DataGramPacket 对象, 用来接收数据, 最大可以传 64kb 的数据
        byte[] buf = new byte[1024];
        DatagramPacket packet = new DatagramPacket(buf, buf.length);
        // 调用接收方法, 将信息填充到 packet 对象中, 若没有接收到数据 则会阻塞
        System.out.println("接收端 A 等待接收数据");
        socket.receive(packet);
        // 拆包, 取出 packet 中的数据
        int length = packet.getLength(); // 实际接收到的数据的长度
        byte[] data = packet.getData(); // 接收到的数据
        String string = new String(data, 0, length);
        System.out.println(string);

        // 回复
        // 将需要发送的数据封装到 DatagramPacket 对象中
        data = "copy that UDP".getBytes(StandardCharsets.UTF_8);
        packet = new DatagramPacket(data, data.length, InetAddress.getByName("192.168.1.4"), 9998);
        // 发送
        socket.send(packet);

        // 关闭资源
        socket.close();
        System.out.println("B 端退出");
    }
}
java 复制代码
public class UDPSenderB {
    public static void main(String[] args) throws IOException {
        // 创建 DataGramSocket 对象, 设置用哪个端口进行发送, 注意同一台机器上不要和接收端的端口冲突
        DatagramSocket socket = new DatagramSocket(9998);
        // 将需要发送的数据封装到 DatagramPacket 对象中
        byte[] data = "hello UDP".getBytes(StandardCharsets.UTF_8);
        DatagramPacket packet = new DatagramPacket(data, data.length, InetAddress.getByName("192.168.1.4"), 9999);
        // 发送
        socket.send(packet);

        // 接收回复
        // 创建一个 DataGramPacket 对象, 用来接收数据, 最大可以传 64kb 的数据
        byte[] buf = new byte[1024];
        packet = new DatagramPacket(buf, buf.length);
        // 调用接收方法, 将信息填充到 packet 对象中, 若没有接收到数据 则会阻塞
        socket.receive(packet);
        // 拆包, 取出 packet 中的数据
        int length = packet.getLength(); // 实际接收到的数据的长度
        data = packet.getData(); // 接收到的数据
        String string = new String(data, 0, length);
        System.out.println(string);

        // 关闭资源
        socket.close();
        System.out.println("B 端退出");
    }
}
相关推荐
雨中飘荡的记忆5 小时前
ElasticJob分布式调度从入门到实战
java·后端
考虑考虑13 小时前
JDK25模块导入声明
java·后端·java ee
_小马快跑_14 小时前
Java 的 8 大基本数据类型:为何是不可或缺的设计?
java
Re_zero17 小时前
线上日志被清空?这段仅10行的 IO 代码里竟然藏着3个毒瘤
java·后端
洋洋技术笔记17 小时前
Spring Boot条件注解详解
java·spring boot
程序员清风1 天前
程序员兼职必看:靠谱软件外包平台挑选指南与避坑清单!
java·后端·面试
皮皮林5512 天前
利用闲置 Mac 从零部署 OpenClaw 教程 !
java
华仔啊2 天前
挖到了 1 个 Java 小特性:var,用完就回不去了
java·后端
SimonKing2 天前
SpringBoot整合秘笈:让Mybatis用上Calcite,实现统一SQL查询
java·后端·程序员
日月云棠2 天前
各版本JDK对比:JDK 25 特性详解
java