socket简单的实现群聊

1.群聊的简单思路实现
在这里插入图片描述
2.群聊的代码实现:

客户端:

/**
* @des 客户端
*                  一个读的子线程 
*                  一个写的子线程
*/
public class Client {

	public static void main(String[] args) throws UnknownHostException, IOException {
		//创建 Socket 
		Socket socket = new Socket("localhost", 9999);
		//启动线程
		// 发送的子线程 
		new Thread(new Send(socket)).start();
		// 接收的子线程 
		new Thread(new Revice(socket)).start();
	}
}

public class IOUitls {
	/**
	 * 泛型方法 流的关闭
	 * @param arr
	 */
	public static <T extends AutoCloseable> void closeAll(T ... arr) {
		for (T t : arr) {
			if (t != null) {
				try {
					t.close();
				} catch (Exception e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
			}
		}
	} 
}

public class Revice implements Runnable{
	//数据流 接收数据  
	private DataInputStream dis = null;
	private boolean isRunning = true;
	public Revice(Socket socket) {
		try {
			// 通过 socket 初始化流的操作 
			dis = new DataInputStream(socket.getInputStream());
		} catch (IOException e) {
			e.printStackTrace();
			//关闭流 
			IOUitls.closeAll(dis,socket);
			isRunning = false;
		}
	}
	/**
	 * 接收数据
	 * @return
	 */
	public String revice() {
		String msg = null;
		try {
			// 读取 字符串 
			msg = dis.readUTF();
		} catch (IOException e) {
			e.printStackTrace();
			// 关闭流
			IOUitls.closeAll(dis);
			isRunning = false;
		}
		return msg;
	}
	@Override
	public void run() {
		//循环的接收数据 
		while (isRunning) {
			System.out.println(revice());
		}
	}
}

public class Send implements Runnable {
	private Scanner sc = null;
	private DataOutputStream dos  = null;
	private boolean isRunning = true;
	public Send(Socket socket) {
		try {
			this.dos = new DataOutputStream(socket.getOutputStream());
			sc = new Scanner(System.in);
		} catch (IOException e) {
			e.printStackTrace();
			IOUitls.closeAll(dos,socket);
			isRunning = false;
		}
	}
	/**
	 * 发送数据
	 */
	public void send() {
		//获取键盘的输入 
		System.out.println("请输入:");
		String msg = sc.next();
		//发送到服务器端 
		try {
			dos.writeUTF(msg);
			dos.flush();
		} catch (IOException e) {
			e.printStackTrace();	
			IOUitls.closeAll(dos);
		}
	}
	@Override
	public void run() {
		while (isRunning) {
			send();
		}
	}
}

服务端代码简单实现:

/**
 * 群聊服务器的实现
 */
public class Server {

    // 服务器 管理集合 的连接通道
    private List<Channel> list = new ArrayList<>();
    public static void main(String[] args) {
        try {
            new Server().start();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
    /**
     * 启动服务器
     */
    private void start() throws IOException {
        ServerSocket socket = new ServerSocket(9999);
        while (true){
            Socket client = socket.accept();
            //来个一个客户端  建立了 通道
            Channel channel = new Channel(client);
            //  添加到集合中进行管理
            list.add(channel);
            //启动线程
            new Thread(channel).start();
        }
    }
    /**
     * 连接通道的类
     */
    class Channel implements Runnable {
        // 2 个流
        private DataInputStream dis = null;
        private DataOutputStream dos = null;

        //传入一个socket 进来
        public Channel(Socket socket) {
            try {
                dis = new DataInputStream(socket.getInputStream());
                dos = new DataOutputStream(socket.getOutputStream());
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        /**
         * 接收数据
         * @return
         */
        public String revice() {
            String msg = null;
            try {
                msg = dis.readUTF();
            } catch (IOException e) {
                e.printStackTrace();
            }
            return msg;
        }
        /**
         * 发送数据
         * @param msg
         */
        public void send(String msg){
            if (msg == null || msg == "" ){
                return;
            }
            try {
                dos.writeUTF(msg);
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        /**
         *  给其他用户发送数据
         */
        public void sendOther(){
            //接收数据
            String msg = revice();
            //给其他用户发送书 循环发送
            for (Channel channel : list) {
                if (channel == this){ // 不给自己发送数据
                    continue;
                }
                channel.send(msg);
            }
        }
        @Override
        public void run() {
            while (true){
                sendOther();
            }
        }
    }
}
### 回答1: 要实现群聊功能,你可以使用 Python 的网络编程库来构建一个简单的聊天服务器。下面是一个简单的例子: ``` import socket # 创建 socket 对象 s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 获取本地主机名 host = socket.gethostname() # 设置端口号 port = 12345 # 绑定端口 s.bind((host, port)) # 设置最大连接数,超过后排队 s.listen(5) while True: # 建立客户端连接 client, addr = s.accept() print("连接地址: %s" % str(addr)) client.send("欢迎访问菜鸟教程!".encode('utf-8')) client.close() ``` 这是一个简单的服务器程序,它接受客户端的连接,并在连接建立后发送一条消息。为了让客户端能够发送消息,你需要编写一个客户端程序。 客户端程序的代码如下所示: ``` import socket # 创建 socket 对象 s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 获取本地主机名 host = socket.gethostname() # 设置端口号 port = 12345 # 连接服务,指定主机和端口 s.connect((host, port)) # 接收小于 1024 字节的数据 msg = s.recv(1024) s.close() print (msg.decode('utf-8')) ``` 这两个程序使用了 TCP 协议来通信。你可以使用多种方 ### 回答2: 要实现Python的群聊功能,可以使用Socket编程来实现。以下是一个简单的示例: 1. 创建服务器端: 首先,我们需要创建一个服务器端,使用Socket中的socket()函数来创建一个套接字,使用bind()函数将套接字与本地IP地址和端口号绑定,然后使用listen()函数开始监听来自客户端的连接请求。当客户端发起连接请求时,我们可以使用accept()函数接受该请求,并创建一个新的线程来处理该客户端的通信。 2. 创建客户端: 客户端需要使用Socket中的socket()函数创建一个套接字,并使用connect()函数来连接服务器端的IP地址和端口号。一旦连接成功,客户端可以发送和接收消息。 3. 实现群聊功能: 要实现群聊功能,可以在服务器端维护一个客户端列表,以便给所有连接的客户端发送消息。当一个客户端发送消息时,服务器可以遍历客户端列表,使用send()函数将消息发送给每个客户端。 需要注意的是,为了确保群聊功能的稳定性和可靠性,我们可能需要使用多线程或多进程来处理多个客户端的连接和通信。 以上是使用Socket编程实现Python的群聊功能的简单示例。实际上,还可以使用其他方法,如使用WebSocket、使用第三方库等来实现群聊功能。 ### 回答3: Python实现群聊功能可以通过使用Socket编程实现。首先,需要创建一个服务器端和多个客户端程序。服务器端负责接收来自不同客户端的消息,并将消息转发给其他客户端。 服务器端程序需要创建一个Socket,并绑定一个IP地址和端口号用于监听客户端的连接。当有客户端连接到服务器时,服务器接收到连接请求,并将客户端添加到一个客户端列表中。 服务器通过循环不断接收来自客户端的消息,并将消息发送给其他所有客户端。当有客户端断开连接时,服务器将其从客户端列表中移除。 客户端程序需要创建一个Socket,并连接到服务器端的IP地址和端口号。客户端可以使用多线程或异步编程实现同时接收和发送消息的功能。客户端接收到消息后,可以将其显示在界面上,并通过向服务器发送消息来实现群聊功能。 通过建立服务器和多个客户端之间的双向通信,实现了多人之间的群聊功能。每个参与群聊的客户端都可以接收其他成员发送的消息,并可以向其他成员发送消息。 Python提供了丰富的网络编程库和框架,例如socket、asyncio和Twisted等,可以帮助我们更轻松地实现群聊功能。根据具体需求和开发能力,可以选择适合的库或框架来实现群聊功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值