Java基于TCP网络编程的群聊功能

服务端

java 复制代码
import java.net.ServerSocket;
import java.net.Socket;
import java.util.ArrayList;
import java.util.List;

public class Server2 {
    public static List<Socket> onlineList = new ArrayList<>();


    public static void main(String[] args) throws  Exception{
        System.out.println("------------服务端启动--------------");
        //创建ServerSocket对象  为服务端注册端口
        ServerSocket socketServer =new ServerSocket(7777);
        while (true){
            //调用accept 方法等待客户端的链接请求
            Socket socket = socketServer.accept();
            onlineList.add(socket);
            System.out.println(socket.getRemoteSocketAddress()+"上线....");
            new ServerReaderThread(socket).start();
        }
    }
}

服务端的线程(用来处理客户端发来的数据)

java 复制代码
import java.io.*;
import java.net.Socket;

public class ServerReaderThread extends  Thread{
        private Socket socket;

        public ServerReaderThread(Socket socket){
                this.socket = socket;
        }
        @Override
        public void run(){
                try{
                        //使用数据输入流  读取 用户发过来的信息
                        //获取字节输入流
                        InputStream ipt = socket.getInputStream();
                        //把原始的字节输入流包装成数据输入流
                        DataInputStream dis =new DataInputStream(ipt);
                        while (true){
                             try{
                                     String rs = dis.readUTF();
                                     System.out.println(rs);
                                     //把这个消息分发给客户端
                                     sendMsgToAll(rs);
                                     System.out.println("------------------------");
                             }catch (Exception e){
                                     System.out.println(socket.getRemoteSocketAddress()+"下线...");
                                     dis.close();
                                     break;
                             }
                        }
                }catch (Exception e){
                        e.printStackTrace();
                }
        }


        private void sendMsgToAll(String msg) throws Exception {
                for (Socket socket1 : Server2.onlineList) {
                        OutputStream os =socket1.getOutputStream();
                        DataOutputStream dos = new DataOutputStream(os);
                        dos.writeUTF(msg);
                        dos.flush();
                }
        }
}

客户端

java 复制代码
import java.io.DataOutput;
import java.io.DataOutputStream;
import java.io.OutputStream;
import java.net.Socket;
import java.util.Scanner;

public class Client2 {
    public static void main(String[] args) throws  Exception {
        //创建一个socket 对象  并同时请求与服务端程序的链接
        Socket socket = new Socket("127.0.0.1",7777);

        //创建一个独立的线程   来读取 服务端发给客户端的消息
        new ClientReaderThread(socket).start();

        //从socket管道中获取字节流 用来发数据给服务端
        OutputStream os = socket.getOutputStream();

        //把低级的字节输出流  换成数据输出流
        DataOutputStream dos =  new DataOutputStream(os);
        //开始写数据
        Scanner sc =new Scanner(System.in);
        while (true){
            System.out.println("user:");
            String msg =sc.nextLine();
            if("exit".equals(msg)){
                System.out.println("退出会话...");
                dos.close();
                //释放连接资源
                socket.close();
                break;
            }
            dos.writeUTF(msg);
            dos.flush();
        }
    }
}

客户端的线程(用于服务端推送的数据)

java 复制代码
import java.io.DataInputStream;
import java.io.InputStream;
import java.net.Socket;

public class ClientReaderThread extends Thread{
    private Socket socket;

    public ClientReaderThread(Socket socket){
        this.socket = socket;
    }
    @Override
    public void run (){
        try{
            //使用数据输入流  读取 用户发过来的信息
            //获取字节输入流
            InputStream ipt = socket.getInputStream();
            //把原始的字节输入流包装成数据输入流
            DataInputStream dis =new DataInputStream(ipt);
            while (true){
                try{
                    String rs = dis.readUTF();
                    System.out.println(rs);
                    System.out.println("------------------------");
                }catch (Exception e){
                    System.out.println(socket.getRemoteSocketAddress()+"下线...");
                    dis.close();
                    break;
                }
            }
        }catch (Exception e){
            e.printStackTrace();
        }
    }
}

效果

此篇基于:

Java网络编程---TCP-CSDN博客

Java网络编程TCP多线程实现服务端接受多个客户端的信息-CSDN博客

实现.....

相关推荐
风逸尘_lz16 小时前
05-LPB3568针对不同网段实现UDP通信
网络·网络协议·udp
chh56316 小时前
C++--内存管理
java·c语言·c++·windows·学习·面试
白緢17 小时前
嵌入式 Linux + 内核开发高频问题及排查
java·linux·运维
学编程就要猛17 小时前
JavaEE初阶:网络编程
运维·服务器·网络
北京聚信万通科技有限公司17 小时前
北京聚信万通科技有限公司获Odette CA官方授权,成为中国区“Odette ID及数字证书”官方注册审批管理机构
网络·科技·汽车·edi·电子数据交换·国产软件
juniperhan17 小时前
Flink 系列第4篇:Flink 时间系统与 Timer 定时器实战精讲
java·大数据·数据仓库·flink
超级大只老咪17 小时前
一维度前缀和解题通用模板(java)
java·开发语言·算法
历程里程碑17 小时前
1 . Git本地操作:版本控制 跨平台协作 仓库核心
java·开发语言·数据结构·c++·git·gitee·github
2501_9481142417 小时前
Claude Sonnet 4.6 深度评测:性能逼近 Opus、成本打骨折,附接入方案与选型指南
大数据·网络·人工智能·安全·架构
hekung17 小时前
maven的lifecycle与idea的run
java·maven