Skip to content

服务器推送信息


设计思路(非常重要!!!

alt text

(1)思路介绍

服务器推送信息的本质是群发,遍历所有线程集合,拿到 socket 后发送信息即可,同时推送信息也需要是一个线程,这里单独启动一个线程用来推送消息

(2)服务端

在 service 包下编写一个类 SendNewsToAllService 继承 Runable 接口

java
package service;

import common.Message;
import common.MessageType;
import utils.Utility;

import java.io.IOException;
import java.io.ObjectOutputStream;
import java.util.Date;
import java.util.HashMap;
import java.util.Iterator;

public class SendNewsToAllService implements Runnable {

    @Override
    public void run() {
        while (true) {
            System.out.println("请输入服务器要推送的信息(输入exit退出)");
            String news = Utility.readString(100);

            if("exite".equals(news)){
                break;
            }
            // 服务器推送信息的本质就是群发
            Message message = new Message();
            message.setSender("服务器");
            message.setContent(news);
            message.setMesType(MessageType.MESSAGE_TO_ALL_MES);
            message.setSendTime(new Date().toString());
            System.out.println("服务器推送信息给所有人说:" + news);

            // 遍历集合,拿到 socket,发送信息
            HashMap<String, ServerConnectClientThread> hm = ManageClientThreads.getHm();
            Iterator<String> iterator = hm.keySet().iterator();
            while (iterator.hasNext()){
                String onLineUserId = iterator.next().toString();
                try {
                    ObjectOutputStream oos = new ObjectOutputStream(hm.get(onLineUserId).getSocket().getOutputStream());
                    oos.writeObject(message);
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
    }
}

🎉 完结:功能测试 🎉

alt text