UDP网络通信反复发&收

java 复制代码
package UDP2;


import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.util.Scanner;

/*
*    完成UDP 通信快速入门    实现发1收1*/
public class Client {
    public static void main(String[] args) throws Exception{
        // 1创建客户端对象
       DatagramSocket socket= new DatagramSocket();

       //2创建数据包对象封装要发出去的数据
      /*    public DatagramPacket(byte buf[], int length,
        InetAddress address, int port)
        参数一 封装要发出去的数据
        参数二 我要发的参数大小
        参数三 服务端IP地址
        参数四 服务端端口

        */

        Scanner sc=new Scanner(System.in);

        while (true) {
            System.out.println("请说:");
           String msg= sc.nextLine();
          byte[] bytes= msg.getBytes();
          // 用户输入exit命令 退出客户端
            if ("exit".equals(msg)){
                System.out.println("欢迎下次光临! 退出成功!");
                socket.close(); //释放资源
                break; //跳出去循环
            }
            DatagramPacket packet =new DatagramPacket(bytes,bytes.length,
                    InetAddress.getLocalHost(),6666);


            // 3:开始正式发送数据包的数据发出去
            socket.send(packet);
        }

    }
}
java 复制代码
package UDP2;

      //完成UDP通信服务端

import java.net.DatagramPacket;
import java.net.DatagramSocket;

public class Server {
    public static void main(String[] args) throws Exception{
        //1创建一个服务端对象
        System.out.println("---------服务端启动---------");
       DatagramSocket socket= new DatagramSocket(6666);

       //2 创建数据对象用接收数据
        byte [] buffer=new byte[1024*64]; //1KB * 64=  64KB
        DatagramPacket packet=new DatagramPacket(buffer,buffer.length);

        while (true) {
            //3:开始正式设用数据包接收客户端发来的数据
            socket.receive(packet);

            //4:字节数组中的数据打印出来
            //接收多少倒出多少
            int lin= packet.getLength();
            String rs=new String(buffer,0,lin);
            System.out.println(rs);


            System.out.println(packet.getAddress().getHostAddress());
            System.out.println(packet.getPort());
            System.out.println("============================================");


        }

    }
}
相关推荐
未秃头的程序猿3 小时前
Java 26正式发布!这3个新特性,让代码量直接减半
java·后端·面试
用户298698530143 小时前
Word 文档文本查找与替换的 Java 实现方案
java·后端
阿哉3 小时前
Nacos 服务发现源码:藏在背后的两套事件机制,90%的人只讲了一半
java
咖啡八杯4 小时前
GoF设计模式——命令模式
java·设计模式·架构
AI人工智能_电脑小能手4 小时前
【大白话说Java面试题 第125题】【并发篇】第25题:说说 Java 线程的中断机制
java·后端·面试
Java内核笔记4 小时前
Spring Security 源码解析(六)无状态 JWT 实践:Session 共享与自定义过滤器
java·后端
荣码4 小时前
LangGraph多Agent协作:3个Agent干活比1个强,但我踩了4个坑
java·python
唐青枫5 小时前
Java 虚拟线程实战指南:从 Thread API 到 Spring Boot 高并发应用
java
白鲸开源21 小时前
Apache SeaTunnel Zeta Engine 的 Basic Auth 是怎么工作的?
java·vue.js·github
白鲸开源21 小时前
一文读懂DolphinScheduler插件机制:如何轻松扩展任务类型与数据源
java·架构·github