聊天系统UDP TCP

服务端

package work;

import java.net.DatagramPacket;

import java.net.DatagramSocket;

import java.util.ArrayList;

import java.util.List;

public class UDPServer {

private static final int PORT = 9876;

private static List<ClientInfo> clients = new ArrayList<>();

public static void main(String[] args) {

try {

DatagramSocket socket = new DatagramSocket(PORT);

System.out.println("UDP 服务器在端口上运行 " + PORT);

while (true) {

byte[] receiveData = new byte[1024];

DatagramPacket receivePacket = new DatagramPacket(receiveData, receiveData.length);

socket.receive(receivePacket);

String message = new String(receivePacket.getData(), 0, receivePacket.getLength());

System.out.println("收到来自 " + receivePacket.getAddress() + ": " + message);

// Broadcast message to all clients

broadcastMessage(message, receivePacket.getAddress(), receivePacket.getPort());

}

} catch (Exception e) {

e.printStackTrace();

}

}

private static void broadcastMessage(String message, java.net.InetAddress address, int port) {

for (ClientInfo client : clients) {

try {

DatagramSocket clientSocket = new DatagramSocket();

byte[] sendData = message.getBytes();

DatagramPacket sendPacket = new DatagramPacket(sendData, sendData.length, client.getAddress(), client.getPort());

clientSocket.send(sendPacket);

clientSocket.close();

} catch (Exception e) {

e.printStackTrace();

}

}

}

private static class ClientInfo {

private java.net.InetAddress address;

private int port;

public ClientInfo(java.net.InetAddress address, int port) {

this.address = address;

this.port = port;

}

public java.net.InetAddress getAddress() {

return address;

}

public int getPort() {

return port;

}

}

}

客服端口

package work;

import java.io.BufferedReader;

import java.io.IOException;

import java.io.InputStreamReader;

import java.io.PrintWriter;

import java.net.Socket;

public class TCPClient {

public static void main(String[] args) {

final String serverAddress = "localhost";

final int serverPort = 12345;

try (Socket socket = new Socket(serverAddress, serverPort)) {

BufferedReader reader = new BufferedReader(new InputStreamReader(socket.getInputStream()));

PrintWriter writer = new PrintWriter(socket.getOutputStream(), true);

// 从服务器接收消息并显示

new Thread(() -> {

try {

String message;

while ((message = reader.readLine()) != null) {

System.out.println("服务器: " + message);

}

} catch (IOException e) {

e.printStackTrace();

}

}).start();

// 从控制台读取输入并发送给服务器

BufferedReader consoleReader = new BufferedReader(new InputStreamReader(System.in));

String consoleInput;

while ((consoleInput = consoleReader.readLine()) != null) {

writer.println(consoleInput);

}

} catch (IOException e) {

e.printStackTrace();

}

}

}

结果:

UDP

客户端

import java.net.DatagramPacket;

import java.net.DatagramSocket;

import java.util.ArrayList;

import java.util.List;

public class UDPServer {

private static final int PORT = 9876;

private static List<ClientInfo> clients = new ArrayList<>();

public static void main(String[] args) {

try {

DatagramSocket socket = new DatagramSocket(PORT);

System.out.println("UDP Server is running on port " + PORT);

while (true) {

byte[] receiveData = new byte[1024];

DatagramPacket receivePacket = new DatagramPacket(receiveData, receiveData.length);

socket.receive(receivePacket);

String message = new String(receivePacket.getData(), 0, receivePacket.getLength());

System.out.println("Received from " + receivePacket.getAddress() + ": " + message);

// Broadcast message to all clients

broadcastMessage(message, receivePacket.getAddress(), receivePacket.getPort());

}

} catch (Exception e) {

e.printStackTrace();

}

}

private static void broadcastMessage(String message, java.net.InetAddress address, int port) {

for (ClientInfo client : clients) {

try {

DatagramSocket clientSocket = new DatagramSocket();

byte[] sendData = message.getBytes();

DatagramPacket sendPacket = new DatagramPacket(sendData, sendData.length, client.getAddress(), client.getPort());

clientSocket.send(sendPacket);

clientSocket.close();

} catch (Exception e) {

e.printStackTrace();

}

}

}

private static class ClientInfo {

private java.net.InetAddress address;

private int port;

public ClientInfo(java.net.InetAddress address, int port) {

this.address = address;

this.port = port;

}

public java.net.InetAddress getAddress() {

return address;

}

public int getPort() {

return port;

}

}

}

服务端

import java.net.DatagramPacket;

import java.net.DatagramSocket;

import java.net.InetAddress;

import java.util.Scanner;

public class UDPClient {

private static final int PORT = 9876;

public static void main(String[] args) {

try {

Scanner scanner = new Scanner(System.in);

System.out.print("Enter your name: ");

String name = scanner.nextLine();

DatagramSocket socket = new DatagramSocket();

InetAddress serverAddress = InetAddress.getByName("localhost");

Thread receiveThread = new Thread(() -> {

try {

byte[] receiveData = new byte[1024];

DatagramPacket receivePacket = new DatagramPacket(receiveData, receiveData.length);

while (true) {

socket.receive(receivePacket);

String message = new String(receivePacket.getData(), 0, receivePacket.getLength());

System.out.println(message);

}

} catch (Exception e) {

e.printStackTrace();

}

});

receiveThread.start();

while (true) {

String message = scanner.nextLine();

String formattedMessage = name + ": " + message;

byte[] sendData = formattedMessage.getBytes();

DatagramPacket sendPacket = new DatagramPacket(sendData, sendData.length, serverAddress, PORT);

socket.send(sendPacket);

}

} catch (Exception e) {

e.printStackTrace();

}

}

}

相关推荐
iナナ10 小时前
传输层协议——UDP和TCP
网络·网络协议·tcp/ip·udp
舒一笑10 小时前
Mac 上安装并使用 frpc(FRP 内网穿透客户端)指南
后端·网络协议·程序员
搬码临时工14 小时前
端口映射原理操作详解教程:实现外网访问内网服务,本地路由器端口映射公网ip和软件端口映射域名2种方法
网络·tcp/ip·智能路由器
Mr_Xuhhh14 小时前
NAT、代理服务、内网穿透
网络·网络协议·http·https·udp·智能路由器
用户849137175471616 小时前
为什么大模型都离不开SSE?带你搞懂第1章〈SSE技术基础与原理〉
前端·网络协议·llm
励志五个月成为嵌入式糕手19 小时前
0819 使用IP多路复用实现TCP并发服务器
java·服务器·tcp/ip
王燕龙(大卫)1 天前
tcp会无限次重传吗
网络·tcp/ip
weisian1511 天前
HTTP协议-3-HTTP/2是如何维持长连接的?
网络·网络协议·http
tan77º1 天前
【项目】分布式Json-RPC框架 - 项目介绍与前置知识准备
linux·网络·分布式·网络协议·tcp/ip·rpc·json
墨雨听阁2 天前
8.18网络编程——基于UDP的TFTP文件传输客户端
网络·网络协议·学习·udp