zoukankan      html  css  js  c++  java
  • Activemq mqtt 点对点聊天实现

    我这想到一个点对点聊天的方法,不用没割人都建立一个topic了,思路还是自定义一个分发策略,具体如下:

    1、  建立一个topic,所有人都用匹配订阅的方式订阅以该topic为头的topic,例如:所有人都订阅PTP/#。

    2、  例如A向B发送聊天信息,B的clientId是bbb,A只需要向PTP/bbb 推送聊天信息,我写的自定义策略会针对所有PTP开头的topic做自定义分发<policyEntry topic="PTP.>">,将topic里的clientId解析出来,并将该消息只发给B。

    自定义策略代码:

    public class ClientIdFilterDispatchPolicy extends SimpleDispatchPolicy {
        public boolean dispatch(MessageReference node,
                MessageEvaluationContext msgContext, List<Subscription> consumers)
                throws Exception {
            System.out.println("--------------------------------来了------------------------------------------");
            System.out.println(node.getMessage().getDestination().getQualifiedName());
            System.out.println(node.getMessage().getDestination().getPhysicalName());
            String topic = node.getMessage().getDestination().getPhysicalName();
            String clientId = topic.substring(topic.indexOf(".")+1, topic.length());
            System.out.println("clientId:" + clientId);
            System.out.println("--------------------------------end------------------------------------------");
            
            if (clientId == null)
                super.dispatch(node, msgContext, consumers);
    
            ActiveMQDestination destination = node.getMessage().getDestination();
    
            int count = 0;
            for (Subscription sub : consumers) {
                if (sub.getConsumerInfo().isBrowser()) {
                    continue;
                }
                if (!sub.matches(node, msgContext)) {
                    sub.unmatched(node);
                    continue;
                }
                System.out.println("isTopic:" + destination.isTopic());
                System.out.println("getClientId:" + sub.getContext().getClientId());
                if ((clientId != null)
                        && (destination.isTopic())
                        && (clientId.equals(sub.getContext().getClientId()))
                        ) {
                    sub.add(node);
                    count++;
                } else {
                    sub.unmatched(node);
                }
            }
    
            return count > 0;
        }
    
        
    }

    activemq.xml

                  <policyEntry topic="PTP.>">
            <dispatchPolicy>
                        <clientIdFilterDispatchPolicy/>
                      </dispatchPolicy>
            </policyEntry>    
  • 相关阅读:
    浅谈C#托管程序中的资源释放问题
    c#基本语法学习笔记
    深入剖析C#多态性
    Reporting Services API
    进程和线程的区别
    化妆品网站,饰品网站
    宠物销售网站
    卖地方特色才产品,类似湖南味道那样的网上专卖店
    建立友情链接联盟
    DIY最残忍U盘
  • 原文地址:https://www.cnblogs.com/momofeng/p/5482775.html
Copyright © 2011-2022 走看看