Java实现UDP通信过程实例分析【服务器端与客户端】
本文实例讲述了Java实现UDP通信过程。分享给大家供大家参考,具体如下:
TCP是一种面向连接的传输层协议,而UDP是传输层中面向无连接的协议,故传送的数据包不能保证有序和不丢失,实现UDP通信主要用到了两个类:DatagramPacket和DatagramSocket。
DatagramSocket
这个类用来表示发送和接收数据包的套接字。
//构造方法,创建数据报套接字并将其绑定到本地主机上的指定端口 DatagramSocket socket = new DatagramSocket(0);
DatagramPacket
表示数据报包,用来实现无连接的包的投递服务。这些数据包选择不同的路由,经过计算机的存储转发,最终到达目的计算机。所以到达的数据包和发送时的顺序不一定会相同。
Sever端程序
一,调用DatagramSocket(int port)创建一个数据报套接字,绑定在指定端口上;
二,调用DatagramPacket(byte[] buf,int length),建立一个字节数组来接收UDP包;
三,调用DatagramSocket.receive();
四,最后关闭数据报套接字。
Client端程序
一,调用DatagramSocket()创建一个数据报套接字;
二,调用DatagramPacket(byte[] buf,int offset,InetAddress address,int port),建立要发送的UDP包
三,调用DatagramSocket类的send方法发送数据包;
四,关闭数据报套接字。
数据报套接字发送成功后,相当于建立了一个虚连接,双方可以发送数据。
实例
服务器端:
/* * 服务器端,实现基于UDP的用户登陆 */ public class UDPServer { public static void main(String[] args) throws IOException { /* * 接收客户端发送的数据 */ // 1.创建服务器端DatagramSocket,指定端口 DatagramSocket socket = new DatagramSocket(8800); // 2.创建数据报,用于接收客户端发送的数据 byte[] data = new byte[1024];// 创建字节数组,指定接收的数据包的大小 DatagramPacket packet = new DatagramPacket(data, data.length); // 3.接收客户端发送的数据 System.out.println("****服务器端已经启动,等待客户端发送数据"); socket.receive(packet);// 此方法在接收到数据报之前会一直阻塞 // 4.读取数据 String info = new String(data, 0, packet.getLength()); System.out.println("我是服务器,客户端说:" + info); /* * 向客户端响应数据 */ // 1.定义客户端的地址、端口号、数据 InetAddress address = packet.getAddress(); int port = packet.getPort(); byte[] data2 = "欢迎您!".getBytes(); // 2.创建数据报,包含响应的数据信息 DatagramPacket packet2 = new DatagramPacket(data2, data2.length, address, port); // 3.响应客户端 socket.send(packet2); // 4.关闭资源 socket.close(); } }
客户端:
/* * 客户端 */ public class UDPClient { public static void main(String[] args) throws IOException { /* * 向服务器端发送数据 */ // 1.定义服务器的地址、端口号、数据 InetAddress address = InetAddress.getByName("localhost"); int port = 8800; byte[] data = "用户名:admin;密码:123".getBytes(); // 2.创建数据报,包含发送的数据信息 DatagramPacket packet = new DatagramPacket(data, data.length, address, port); // 3.创建DatagramSocket对象 DatagramSocket socket = new DatagramSocket(); // 4.向服务器端发送数据报 socket.send(packet); /* * 接收服务器端响应的数据 */ // 1.创建数据报,用于接收服务器端响应的数据 byte[] data2 = new byte[1024]; DatagramPacket packet2 = new DatagramPacket(data2, data2.length); // 2.接收服务器响应的数据 socket.receive(packet2); // 3.读取数据 String reply = new String(data2, 0, packet2.getLength()); System.out.println("我是客户端,服务器说:" + reply); // 4.关闭资源 socket.close(); } }
更多关于java相关内容感兴趣的读者可查看本站专题:《Java Socket编程技巧总结》、《Java文件与目录操作技巧汇总》、《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》和《Java缓存操作技巧汇总》
希望本文所述对大家java程序设计有所帮助。
您可能感兴趣的文章:
- java UDP通信客户端与服务器端实例分析
- Linux socket编程入门及客户端服务器端通信实现 – 提高篇:TCP连接过程分析
- java udp网络编程及实例代码,实现客户端和服务端通信
- 下联网关国标对接中的通信过程分析和实例之客户端主动发起的实时音视频点播过程
- UDP的客户端和服务器端的实例(VC6.0实现)
- java模拟TCP通信--实现客户端上传文件到服务器端
- 应用java多线程实现服务器端与多客户端之间的通信
- java Tcp通信客户端与服务器端实例
- java学习笔记-----qq项目----在服务器端实现两个客户端的通信的原理
- JAVA实现NIO非阻塞UDP通信--客户端
- Java 基于 UDP 实现 Socket中的多客户端通信
- javaspript基础,Ajax实现客户端与服务器端通信
- java模拟TCP通信实现客户端上传文件到服务器端
- Java 基于 UDP 实现 Socket中的多客户端通信
- OpenStack建立实例完整过程源码详细分析(14)----依据AMQP通信架构实现消息接收机制解析之一
- C#基于TCP&UDP实现服务器与多个客户端之间的通信(客户端之间直接通信,不靠服务器端转发消息)
- python网络编程之UDP通信实例(含服务器端、客户端、UDP广播例子)
- java-基本的Socket编程-实现服务器端和客户端通信