【附源码下载】基于Springboot1.5.2/dubbo2.8.4实现Websocket广播和点对点消息推送

写在前边的话:此项目基于springboot1.5.2版本,dubbo使用2.8.4,使用thymleaf为渲染模板,jdk1.7,如springboot为2.0以上版本,请使用jdk1.8,相关接口实现也均已变更。【本人亲测可用,附源码下载地址,可自行下载】


以下代码编辑器格式有点乱, 拷贝后自行格式化


二. 相关代码

0. 变量集合

package com.song.config;/** * 常量 * * @author songshijun * @time 2018-03-27 */public class Constants {/**    * socket常量    */    public static class WebSocket{public static StringWEBSOCKETPATHPERFIX ="/send";public static StringREGISTRY_MSGCENTER ="/registry/msgcenter";//广播中心地址        /** 点对点 */        public static final StringP2PPUSHBASEPATH ="/p2p";//点对点消息推送地址前缀        public static final StringP2PPUSHPATH ="/msg";//点对点消息推送地址后缀,地址: /user/用户识别码/msg        /** 广播地址 */        public static final StringMSGMAPPING_BROADCAST="/broadcast";//消息代理路径        public static final StringRESPONSE_BROADCAST ="/broadcast/response";//客户端订阅地址接收服务端消息    }}

1. websocket相关配置

public class WebSocketConfigextends AbstractWebSocketMessageBrokerConfigurer {@Override    public void registerStompEndpoints(StompEndpointRegistry arg0) {        arg0.addEndpoint(WebSocket.REGISTRY_MSGCENTER).withSockJS();    }@Override    public void configureMessageBroker(MessageBrokerRegistry registry) {//服务端发送消息给客户端的域,多个用逗号隔开        registry.enableSimpleBroker(WebSocket.MSGMAPPING_BROADCAST, WebSocket.P2PPUSHBASEPATH);        registry.setUserDestinationPrefix(WebSocket.P2PPUSHBASEPATH);//定义一对一推送的时候前缀        registry.setApplicationDestinationPrefixes(WebSocket.WEBSOCKETPATHPERFIX);//客户端消息推送路由前缀    }}

2. 消息实体

WiselyMessage.java

package com.song.model;/** * 发送消息实体类 * * @author songshijun * @time 2018-03-27 */public class WiselyMessage {private Stringname;private StringuserId;public String getName() {return name;    }public void setName(String name) {this.name = name;    }public String getUserId() {return userId;    }public void setUserId(String userId) {this.userId = userId;    }}

WiselyResponse.java

package com.song.model;/** * 返回消息实体类 * * @author songshijun * @time 2018-03-27 */public class WiselyResponse {private StringresponseMessage;public String getResponseMessage() {return responseMessage;    }public void setResponseMessage(String responseMessage) {this.responseMessage = responseMessage;    }}

3. 消息发送接口

package com.song.service;import com.song.model.WiselyResponse;import java.util.List;/** * 消息发送接口 * * @author songshijun * @time 2018-03-27 */public interface WebsocketService {void send2Users(List users, WiselyResponse msg);}

4. 消息接口实现类

package com.song.serviceimpl;import static com.song.config.Constants.WebSocket;import com.song.model.WiselyResponse;import com.song.service.WebsocketService;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.messaging.simp.SimpMessagingTemplate;import org.springframework.stereotype.Service;import java.util.List;/** * 消息发送实体类 * * @author songshijun * @time 2018-03-27 */@Servicepublic class WebsocketServiceImplimplements WebsocketService{@Autowired    private SimpMessagingTemplatetemplate;/**    * 发送给指定用户    *    * @param users    * @param msg    */    @Override    public void send2Users(List users, WiselyResponse msg) {for(String user:users){template.convertAndSendToUser(user, WebSocket.P2PPUSHPATH, msg);        }    }}

5. websocket测试主页

html><html xmlns:th="http://www.thymleaf.org"><head><meta charset="UTF-8"/><title th:text="'当前广播站点'+${userId}">title><link rel="stylesheet" th:href="@{/css/app/websocketBroadcast.css}"/>head><body><div><button id="connect" onclick="SocketBroad.connect()">连接button><button id="disconnect" onclick="SocketBroad.disconnect();">断开连接button>div><div id="conversationDiv"><div class="main"><div>广播发送 -->                <span style="margin-top:50px">MSG SEND:<input type="text" id="broadcast" placeholder="请输入广播发布的信息"/>span><span><button onclick="SocketBroad.sendBroadcast();">广播发送button>span><br/>点对点发送 -->                <span style="margin-top:50px">MSG SEND:<input type="text" id="p2p" placeholder="请输入点对点发布的信息"/><input type="text" id="toUser" placeholder="请输入要推送的用户ID"/>span><span><button onclick="SocketBroad.sendP2p();">点对点发送button>span><br/><br/>消息推送页面显示 -->                <span style="margin-top:50px">Receive the broadcast message:span><span><p id="response">p>span><span style="margin-top:50px">Receive the P2P message:span><span><p id="response1">p>span>div>div>div><script type="text/javascript" th:src="@{/js/common/stomp.min.js}">script><script type="text/javascript" src="/js/common/sockjs.min.js">script><script type="text/javascript" src="/js/common/jquery-1.8.3.min.js">script><script type="text/javascript" src="/js/app/socketBroad.js">script><script th:inline="javascript">var userId= [[${userId}]];script>body>html>

6. 页面逻辑js

var SocketBroad = (function($){var stompClient =null;/**    * 连接设置    *    * @param connected    */    var setConnected =function (connected) {document.getElementById('connect').disabled = connected;document.getElementById('disconnect').disabled = !connected;document.getElementById('conversationDiv').style.visibility = connected ?'visible' :'hidden';        $('#response').html();    }/**    * 建立长连接    */    var connect =function () {var socket =new SockJS('/registry/msgcenter');stompClient =Stomp.over(socket);stompClient.connect({},function(frame) {setConnected(true);console.log('Connected:' + frame);//地址订阅            stompClient.subscribe('/broadcast/response',function(response) {console.log(response)showResponse(JSON.parse(response.body).responseMessage);            });stompClient.subscribe('/p2p/' +userId +'/msg',function(respnose){console.log(respnose);showResponse1(JSON.parse(respnose.body).responseMessage);            });        });    }/**    * 断开连接    */    var disconnect =function () {if (stompClient !=null) {stompClient.disconnect();        }setConnected(false);console.log("Disconnected");    }/**    * 发布广播消息    */    var sendBroadcast =function () {var name = $('#broadcast').val();stompClient.send("/send/broadcast", {},JSON.stringify({name:name}));    }var sendP2p =function(){var name = $('#p2p').val();var userId = $('#toUser').val();if(!userId){alert("请输入要推送的用户ID");return;        }stompClient.send("/send/p2p", {},JSON.stringify({name:name,userId:userId}));    }/**    * 渲染接接收的广播消息    * @param message    */    var showResponse =function (message) {var response = $('#response');response.html(message);    }var showResponse1 =function (message) {var response = $("#response1");response.html(message);    }return {connect:connect,disconnect:disconnect,sendBroadcast:sendBroadcast,sendP2p:sendP2p    }})(jQuery)$(function(){SocketBroad.disconnect();})


源码下载地址:【该地址同步本人CSDN账号非盗用】https://download.csdn.net/download/u011127348/10311990

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,658评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,482评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,213评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,395评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,487评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,523评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,525评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,300评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,753评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,048评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,223评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,905评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,541评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,168评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,417评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,094评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,088评论 2 352

推荐阅读更多精彩内容