TCP通信实现:多发多收消息、实现可以同时接收多个客户端

客户端

java 复制代码
package com.csdn.d5_socket2;

import java.io.IOException;
import java.io.OutputStream;
import java.io.PrintStream;
import java.net.Socket;
import java.util.Scanner;

/**
 * 目标:完成 Socket  客户端开发,实现 多发 和 多收
 */
public class ClientDemo1 {
    public static void main(String[] args) {

        try{
            System.out.println("===客户端启动===");
            //1、创建Socket通信管道请求有服务端的连接
            Socket socket = new Socket("127.0.0.1", 7777);
            //2、从socket通信管道中得到一个字节输出流 负责发送数据
            OutputStream os = socket.getOutputStream();
            //3、把低级的字节流包装成打印流
            PrintStream ps = new PrintStream(os);

            Scanner sc = new Scanner(System.in);
            while (true) {
                System.out.println("请说:");
                String msg = sc.nextLine();
                //4、发送消息
                ps.println(msg);
                ps.flush();
            }

        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
}

服务端

java 复制代码
package com.csdn.d5_socket2;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.ServerSocket;
import java.net.Socket;

/**
 * 目标:实现 服务端 可以同时处理 多个客户端 的消息
 */
public class ServerDemo2 {
    public static void main(String[] args) {

        try {
            System.out.println("===服务端启动成功===");
            //1、注册端口
            ServerSocket serverSocket = new ServerSocket(7777);
            //a.定义一个死循环由主线程负责不断的接收客户端的Socket管道连接
            while (true) {
                //2、每接收到一个客户端的Socket管道,交给一个独立的子线程负责读取消息
                Socket socket = serverSocket.accept();
                //上线逻辑
                System.out.println(socket.getRemoteSocketAddress() + "它来了,上线了!");
                //3、开始创建独立线程处理socket
                new ServerReaderThread(socket).start();

            }

        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
}

class ServerReaderThread extends Thread {
    private Socket socket;

    public ServerReaderThread(Socket socket) {
        this.socket = socket;
    }
    @Override
    public void run() {
        try {
            //3、从socket通信管道中得到一个字节输入流
            InputStream is = socket.getInputStream();
            //4、把字节输入流包装成缓冲字符输入流进行消息的接收
            BufferedReader br = new BufferedReader(new InputStreamReader(is));
            //5、按照行读取消息
            String msg;
            while ((msg = br.readLine()) != null) {
                System.out.println(socket.getRemoteSocketAddress() + "说了:" + msg);
            }
        } catch (IOException e) {
            System.out.println(socket.getRemoteSocketAddress() + "下线了!!!");
        }
    }
}
相关推荐
-孤存-14 分钟前
深入浅出:TCP/UDP协议核心原理
网络·网络协议·tcp/ip·1024程序员节
重回19813 小时前
企业微信可信IP配置的Python完美解决方案
网络协议·tcp/ip·企业微信
悲伤小伞8 小时前
Linux_Socket_UDP
linux·服务器·网络·c++·网络协议·udp
quant_198611 小时前
【教程】使用加密货币行情接口 - 查询比特币实时价格
开发语言·后端·python·websocket·网络协议
Jerry25050914 小时前
怎么才能实现网站HTTPS访问?
网络协议·http·网络安全·https·ssl
特轮飞15 小时前
Linux网络协议ARP IGMP ICMP的理解
linux·运维·网络协议
tang7778915 小时前
对抗高级反爬:基于动态代理 IP 的浏览器指纹模拟与轮换策略
网络·网络协议·tcp/ip
好记忆不如烂笔头abc15 小时前
Configuration of TCP/IP with SSL and TLS for Database Connections
数据库·网络协议·ssl
爱编程的鱼18 小时前
HTTP 是什么?它是如何工作的
网络·网络协议·http
刘一说19 小时前
CentOS Stream 网络故障排查:静态IP丢失、无法访问的完整解决方案
linux·tcp/ip·centos