Java网络编程UDP的使用
本文将展示UDP的使用例子,来阐述它的使用方法。
一.服务器端
package com.xykj.udp;
import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetSocketAddress;
import java.net.SocketAddress;
import java.net.SocketException;
/**
* 这里要注意UDP类里面收包和发包的协议的方法都在里面
* 数据传输的整个过程相当于:
* 服务器-->先启动,一直在等待接收数据包
* 客户端-->调用UDP服务器的发包方法给相应的地方发包
* 然后,相应的地址(这里只有一个,实际中可以多态电脑联机)-->调用自身的的收包方法来接收包,并把数据读取出来
* 然后可以发包、接包一直循环
* */
public class UDP extends Thread {
// 收发数据
DatagramSocket socket = null;
// 端口号
public UDP(int port) {
try {
// 服务器监听的端口号
socket = new DatagramSocket(port);
} catch (SocketException e) {
e.printStackTrace();
}
}
// 发送数据报 1.对方端口 2.对方ip 3.数据
public void sendMessage(String host, int port, String msg) {
// 建立发送信息的主机地址
SocketAddress address = new InetSocketAddress(host, port);
// 建立数据报,长度一定要注意要先转字节后在获取长度
DatagramPacket packet = new DatagramPacket(msg.getBytes(),
msg.getBytes().length, address);
try {
// 发送数据报
socket.send(packet);
} catch (IOException e) {
e.printStackTrace();
}
}
// 收包
@Override
public void run() {
super.run();
// 一个包如果缓冲不过来就丢失了
byte[] buf = new byte[65535];
DatagramPacket dPacket = new DatagramPacket(buf, buf.length);
try {
while (true) {
//收包的方法
// 阻塞式方法
socket.receive(dPacket);
// 收到了数据包,要对数据报进行拆包
String msg = new String(dPacket.getData(), 0,
dPacket.getLength());
// 把接收到的数据打印出来
System.out.println(msg);
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
二.客户端
package com.xykj.udp;
import java.util.Scanner;
public class UDPTest {
/*
* 主调用方法
* 这里服务器的启动和客户端的实现都在同一个类中,其实分开也是可以的
*
*/
public static void main(String[] args) {
// 接收方(服务器)
UDP udp = new UDP(7777);// 接收方定的端口号
udp.start();
// 发送方(客户端)
Scanner scanner = new Scanner(System.in);
for (int i = 0; i < 5; i++) {
String msg = scanner.next();
// 发送方要发送的地址,和端口号,还有信息,192.168.18.255本局域网的广播地址
udp.sendMessage("192.168.18.255", 7777, msg);
}
scanner.close();
}
}
这个程序可以多人使用,就是群聊的功能。
值得注意的是:这里的广播地址,我本人的局域网的广播地址,其他的要自己查,
这只是其中一种广播格式:192.168.XXX.255。
如果想实现私聊功能,可以另写一个方法,把指定的IP地址传进去,就可以对单个人发送短信!
UDP也可以传输文件,但是大小有限制,如果传输大文件可能会丢失数据。