摘要:注冊(cè)一個(gè)的節(jié)點(diǎn)并指定使用協(xié)議。通過(guò)訂閱服務(wù)器的目標(biāo)是接收一對(duì)一的推送消息其中由服務(wù)端傳遞過(guò)來(lái)用于表示唯一的用戶(hù)通過(guò)此值將消息精確推送給一個(gè)用戶(hù)通過(guò)向地址為的服務(wù)器地址發(fā)起請(qǐng)求,與里的地址對(duì)應(yīng)。
springboot基礎(chǔ)環(huán)境,請(qǐng)參考springboot文檔
maven依賴(lài)
org.springframework.boot spring-boot-starter-websocket
代碼準(zhǔn)備
準(zhǔn)備常量類(lèi)
//webSocket相關(guān)配置 //鏈接地址 public static String WEBSOCKETPATHPERFIX = "/ws-push"; public static String WEBSOCKETPATH = "/endpointWisely"; //消息代理路徑 public static String WEBSOCKETBROADCASTPATH = "/topic"; //前端發(fā)送給服務(wù)端請(qǐng)求地址 public static final String FORETOSERVERPATH = "/welcome"; //服務(wù)端生產(chǎn)地址,客戶(hù)端訂閱此地址以接收服務(wù)端生產(chǎn)的消息 public static final String PRODUCERPATH = "/topic/getResponse"; //點(diǎn)對(duì)點(diǎn)消息推送地址前綴 public static final String P2PPUSHBASEPATH = "/user"; //點(diǎn)對(duì)點(diǎn)消息推送地址后綴,最后的地址為/user/用戶(hù)識(shí)別碼/msg public static final String P2PPUSHPATH = "/msg";
接收前端消息實(shí)體
public class WiselyMessage { private String name; public String getName() { return name; } public void setName(String name) { this.name = name; }
}
后臺(tái)發(fā)送消息實(shí)體
private String responseMessage; public WiselyResponse(String responseMessage){ this.responseMessage = responseMessage; } public String getResponseMessage() { return responseMessage; } public void setResponseMessage(String responseMessage) { this.responseMessage = responseMessage; }
配置websocket
@Configuration // @EnableWebSocketMessageBroker注解用于開(kāi)啟使用STOMP協(xié)議來(lái)傳輸基于代理(MessageBroker)的消息,這時(shí)候控制器(controller)開(kāi)始支持@MessageMapping,就像是使用@requestMapping一樣。 @EnableWebSocketMessageBroker public class WebSocketConfig extends AbstractWebSocketMessageBrokerConfigurer { @Override public void registerStompEndpoints(StompEndpointRegistry stompEndpointRegistry) { //注冊(cè)一個(gè)Stomp的節(jié)點(diǎn)(endpoint),并指定使用SockJS協(xié)議。 stompEndpointRegistry.addEndpoint(Constant.WEBSOCKETPATH).withSockJS(); } @Override public void configureMessageBroker(MessageBrokerRegistry registry) { //服務(wù)端發(fā)送消息給客戶(hù)端的域,多個(gè)用逗號(hào)隔開(kāi) registry.enableSimpleBroker(Constant.WEBSOCKETBROADCASTPATH, Constant.P2PPUSHBASEPATH); //定義一對(duì)一推送的時(shí)候前綴 registry.setUserDestinationPrefix(Constant.P2PPUSHBASEPATH); //定義websoket前綴 registry.setApplicationDestinationPrefixes(Constant.WEBSOCKETPATHPERFIX); } }
service
@Service public class WebSocketService { @Autowired private SimpMessagingTemplate template; /** * 廣播 * 發(fā)給所有在線用戶(hù) * @param msg */ public void sendMsg(WiselyResponse msg) { template.convertAndSend(Constant.PRODUCERPATH, msg); } /** * 發(fā)送給指定用戶(hù) * @param users * @param msg */ public void send2Users(Listusers, WiselyResponse msg) { users.forEach(userName -> { template.convertAndSendToUser(userName, Constant.P2PPUSHPATH, msg); }); } }
控制器
@Controller public class WsController { @Resource WebSocketService webSocketService; @MessageMapping(Constant.FORETOSERVERPATH)//@MessageMapping和@RequestMapping功能類(lèi)似,用于設(shè)置URL映射地址,瀏覽器向服務(wù)器發(fā)起請(qǐng)求,需要通過(guò)該地址。 @SendTo(Constant.PRODUCERPATH)//如果服務(wù)器接受到了消息,就會(huì)對(duì)訂閱了@SendTo括號(hào)中的地址傳送消息。 public WiselyResponse say(WiselyMessage message) throws Exception { Listusers = Lists.newArrayList(); users.add("d892bf12bf7d11e793b69c5c8e6f60fb");//此處寫(xiě)死只是為了方便測(cè)試,此值需要對(duì)應(yīng)頁(yè)面中訂閱個(gè)人消息的userId webSocketService.send2Users(users, new WiselyResponse("admin hello")); return new WiselyResponse("Welcome, " + message.getName() + "!"); } }
頁(yè)面
Spring Boot+WebSocket+廣播式
測(cè)試
點(diǎn)擊連接控制臺(tái)輸出
表示連接成功并且訂閱了兩個(gè)地址
此時(shí)在文本框內(nèi)輸入任意值
結(jié)果如圖所示則代表成功
控制臺(tái)中顯示依次為,發(fā)送信息,目標(biāo)長(zhǎng)度內(nèi)容
此時(shí)服務(wù)端控制器接收到請(qǐng)求
同時(shí)給指定用戶(hù)發(fā)送了消息,所以控制臺(tái)接收到消息
同時(shí)因?yàn)榭刂破饔凶⒔釦SendTo所以會(huì)向@SendTo的地址廣播消息,客戶(hù)端訂閱了廣播地址所有控制臺(tái)顯示接收了消息
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/69388.html
摘要:注冊(cè)一個(gè)的節(jié)點(diǎn)并指定使用協(xié)議。通過(guò)訂閱服務(wù)器的目標(biāo)是接收一對(duì)一的推送消息其中由服務(wù)端傳遞過(guò)來(lái)用于表示唯一的用戶(hù)通過(guò)此值將消息精確推送給一個(gè)用戶(hù)通過(guò)向地址為的服務(wù)器地址發(fā)起請(qǐng)求,與里的地址對(duì)應(yīng)。 springboot基礎(chǔ)環(huán)境,請(qǐng)參考springboot文檔 maven依賴(lài) org.springframework.boot ...
摘要:我們只需引入如下依賴(lài)即可注入首先注入一個(gè)該會(huì)自動(dòng)注冊(cè)使用注解申明的。 一、背景 ??我們都知道 http 協(xié)議只能瀏覽器單方面向服務(wù)器發(fā)起請(qǐng)求獲得響應(yīng),服務(wù)器不能主動(dòng)向?yàn)g覽器推送消息。想要實(shí)現(xiàn)瀏覽器的主動(dòng)推送有兩種主流實(shí)現(xiàn)方式: 輪詢(xún):缺點(diǎn)很多,但是實(shí)現(xiàn)簡(jiǎn)單 websocket:在瀏覽器和服務(wù)器之間建立 tcp 連接,實(shí)現(xiàn)全雙工通信 ??springboot 使用 websocket 有...
摘要:無(wú)證連接進(jìn)行異常記錄并關(guān)閉連接。離線消息檢測(cè)到上線立即推送這是消息推送需要實(shí)現(xiàn)的基本功能之一了,詳見(jiàn)代碼。主要功能協(xié)助進(jìn)行初始化,心跳包檢測(cè),斷線自動(dòng)重連消息推送的第二種方式在下篇中再編寫(xiě) 消息重發(fā)中需要注意的問(wèn)題 由于最近工作中接觸了比較多關(guān)閉消息推送以及異常重發(fā)機(jī)制的問(wèn)題,終于得空總結(jié)一下經(jīng)驗(yàn) 目前接觸的消息推送分為兩種 主動(dòng)推送:一般為websocket建立長(zhǎng)連接實(shí)現(xiàn),此處網(wǎng)上...
閱讀 2019·2021-11-24 09:39
閱讀 1882·2019-08-30 15:55
閱讀 2175·2019-08-30 15:53
閱讀 572·2019-08-29 13:16
閱讀 990·2019-08-26 12:20
閱讀 2387·2019-08-26 11:58
閱讀 3151·2019-08-26 10:19
閱讀 3310·2019-08-23 18:31