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

}

}

}

相关推荐
2401_89044302几秒前
传输层协议TCP
网络·网络协议·tcp/ip
玥轩_52111 分钟前
静态路由原理 及实验案例
网络·网络协议·网络安全·智能路由器·路由器·交换机
while(1){yan}1 小时前
数据链路层与物理层
java·网络·网络协议
大白同学4212 小时前
UDP Socket编程的三级跳:简单到复杂的优雅过渡
网络·网络协议·udp
那我掉的头发算什么2 小时前
【javaEE】IP协议详解
网络·网络协议·tcp/ip·计算机网络
爱尔兰极光2 小时前
计算机网络-- TCP
网络·tcp/ip·计算机网络
爬山算法3 小时前
Netty(22)如何实现基于Netty的HTTP客户端和服务器?
服务器·网络协议·http
羑悻的小杀马特3 小时前
【Linux篇章】再续传输层协议TCP:用技术隐喻重构网络世界的底层逻辑,用算法演绎‘网络因果律’的终极推演(通俗理解TCP协议,这一篇就够了)!
linux·网络·后端·tcp/ip·tcp协议
博语小屋3 小时前
Socket 编程TCP:多线程远程命令执行
linux·网络·c++·网络协议·tcp/ip
老蒋新思维13 小时前
创客匠人启示:破解知识交付的“认知摩擦”——IP、AI与数据的三角解耦模型
大数据·人工智能·网络协议·tcp/ip·重构·创客匠人·知识变现