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

服务线程

java 复制代码
import java.io.DataInputStream;
import java.io.InputStream;
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);
                                     System.out.println("------------------------");
                             }catch (Exception e){
                                     System.out.println(socket.getRemoteSocketAddress()+"下线...");
                                     break;
                             }
                        }
                }catch (Exception e){
                        e.printStackTrace();
                }
        }
}

服务端

java 复制代码
import java.net.ServerSocket;
import java.net.Socket;

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

客户端

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);
        //从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();
        }
    }
}

效果

相关推荐
代码老y4 分钟前
Spring Boot + 本地部署大模型实现:优化与性能提升
java·spring boot·后端
数据与人工智能律师8 分钟前
数字资产革命中的信任之锚:RWA法律架构的隐形密码
大数据·网络·人工智能·云计算·区块链
GodKeyNet8 分钟前
设计模式-桥接模式
java·设计模式·桥接模式
菜包eo1 小时前
二维码驱动的独立站视频集成方案
网络·python·音视频
guojl1 小时前
Java多任务编排技术
java
丶意冷1 小时前
mybatisPlus分页方言设置错误问题 mybatisPlus对于Oceanbase的Oracle租户分页识别错误
java·数据库·oracle·oceanbase
yzx9910131 小时前
关于网络协议
网络·人工智能·python·网络协议
zsq1 小时前
【网络与系统安全】域类实施模型DTE
网络·安全·系统安全
要开心吖ZSH2 小时前
《Spring 中上下文传递的那些事儿》Part 4:分布式链路追踪 —— Sleuth + Zipkin 实践
java·分布式·spring
桦说编程2 小时前
深入解析CompletableFuture源码实现
java·性能优化·源码