聊天系统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();

}

}

}

相关推荐
无证驾驶梁嗖嗖5 小时前
无需公网 IP,MongoDB 也能跨环境访问?试试这个实用方案
网络协议·tcp/ip·mongodb
Mu.3876 小时前
计算机网络模型
网络·网络协议·计算机网络·安全·http·https
xu_yule11 小时前
网络和Linux网络-3(套接字编程)TCP网络通信代码
linux·网络·tcp/ip
飞行增长手记15 小时前
什么是高匿代理IP?安全吗?怎么选?
网络协议·tcp/ip·安全
上海云盾安全满满20 小时前
高防 IP 是如何帮助数藏行业防刷
网络·网络协议·tcp/ip
吠品21 小时前
免费SSL证书自动化申请:DNS代理验证
网络协议·自动化·ssl
捷米研发三部1 天前
CC-Link转Modbus TCP协议转换网关实现三菱 PLC与传感器通讯在快递分拣中心的应用案例
网络·网络协议
嵌入式-小王1 天前
每天掌握一个网络协议----ARP协议
网络·网络协议·arp
阿珊和她的猫1 天前
HTTP 状态码 301 和 302 的区别与使用场景
网络·网络协议·http
让学习成为一种生活方式1 天前
植物中验证蛋白相互作用的Pull-down和Co-IP技术--文献精读181
网络·网络协议·tcp/ip