摘要:注冊一個的節點并指定使用協議。通過訂閱服務器的目標是接收一對一的推送消息其中由服務端傳遞過來用于表示唯一的用戶通過此值將消息精確推送給一個用戶通過向地址為的服務器地址發起請求,與里的地址對應。
springboot基礎環境,請參考springboot文檔
maven依賴
org.springframework.boot spring-boot-starter-websocket
代碼準備
準備常量類
//webSocket相關配置 //鏈接地址 public static String WEBSOCKETPATHPERFIX = "/ws-push"; public static String WEBSOCKETPATH = "/endpointWisely"; //消息代理路徑 public static String WEBSOCKETBROADCASTPATH = "/topic"; //前端發送給服務端請求地址 public static final String FORETOSERVERPATH = "/welcome"; //服務端生產地址,客戶端訂閱此地址以接收服務端生產的消息 public static final String PRODUCERPATH = "/topic/getResponse"; //點對點消息推送地址前綴 public static final String P2PPUSHBASEPATH = "/user"; //點對點消息推送地址后綴,最后的地址為/user/用戶識別碼/msg public static final String P2PPUSHPATH = "/msg";
接收前端消息實體
public class WiselyMessage { private String name; public String getName() { return name; } public void setName(String name) { this.name = name; } }
后臺發送消息實體
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注解用于開啟使用STOMP協議來傳輸基于代理(MessageBroker)的消息,這時候控制器(controller) // 開始支持@MessageMapping,就像是使用@requestMapping一樣。 @EnableWebSocketMessageBroker public class WebSocketConfig extends AbstractWebSocketMessageBrokerConfigurer { @Override public void registerStompEndpoints(StompEndpointRegistry stompEndpointRegistry) { //注冊一個Stomp的節點(endpoint),并指定使用SockJS協議。 stompEndpointRegistry.addEndpoint(Constant.WEBSOCKETPATH).withSockJS(); } @Override public void configureMessageBroker(MessageBrokerRegistry registry) { //服務端發送消息給客戶端的域,多個用逗號隔開 registry.enableSimpleBroker(Constant.WEBSOCKETBROADCASTPATH, Constant.P2PPUSHBASEPATH); //定義一對一推送的時候前綴 registry.setUserDestinationPrefix(Constant.P2PPUSHBASEPATH); //定義websoket前綴 registry.setApplicationDestinationPrefixes(Constant.WEBSOCKETPATHPERFIX); } }
service
@Service public class WebSocketService { @Autowired private SimpMessagingTemplate template; /** * 廣播 * 發給所有在線用戶 * * @param msg */ public void sendMsg(WiselyResponse msg) { template.convertAndSend(Constant.PRODUCERPATH, msg); } /** * 發送給指定用戶 * @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功能類似,用于設置URL映射地址,瀏覽器向服務器發起請求,需要通過該地址。 @SendTo(Constant.PRODUCERPATH)//如果服務器接受到了消息,就會對訂閱了@SendTo括號中的地址傳送消息。 public WiselyResponse say(WiselyMessage message) throws Exception { Listusers = Lists.newArrayList(); users.add("d892bf12bf7d11e793b69c5c8e6f60fb");//此處寫死只是為了方便測試,此值需要對應頁面中訂閱個人消息的userId webSocketService.send2Users(users, new WiselyResponse("admin hello")); return new WiselyResponse("Welcome, " + message.getName() + "!"); } }
頁面
Spring Boot+WebSocket+廣播式
測試
點擊連接控制臺輸出
表示連接成功并且訂閱了兩個地址
此時在文本框內輸入任意值 結果如圖所示則代表成功
控制臺中顯示依次為,發送信息,目標長度內容
此時服務端控制器接收到請求
同時給指定用戶發送了消息,所以控制臺接收到消息
同時因為控制器有注解@SendTo所以會向@SendTo的地址廣播消息,客戶端訂閱了廣播地址所有控制臺顯示接收了消息
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/67984.html
摘要:注冊一個的節點并指定使用協議。通過訂閱服務器的目標是接收一對一的推送消息其中由服務端傳遞過來用于表示唯一的用戶通過此值將消息精確推送給一個用戶通過向地址為的服務器地址發起請求,與里的地址對應。 springboot基礎環境,請參考springboot文檔maven依賴 org.springframework.boot spring-boot-s...
摘要:我們只需引入如下依賴即可注入首先注入一個該會自動注冊使用注解申明的。 一、背景 ??我們都知道 http 協議只能瀏覽器單方面向服務器發起請求獲得響應,服務器不能主動向瀏覽器推送消息。想要實現瀏覽器的主動推送有兩種主流實現方式: 輪詢:缺點很多,但是實現簡單 websocket:在瀏覽器和服務器之間建立 tcp 連接,實現全雙工通信 ??springboot 使用 websocket 有...
摘要:無證連接進行異常記錄并關閉連接。離線消息檢測到上線立即推送這是消息推送需要實現的基本功能之一了,詳見代碼。主要功能協助進行初始化,心跳包檢測,斷線自動重連消息推送的第二種方式在下篇中再編寫 消息重發中需要注意的問題 由于最近工作中接觸了比較多關閉消息推送以及異常重發機制的問題,終于得空總結一下經驗 目前接觸的消息推送分為兩種 主動推送:一般為websocket建立長連接實現,此處網上...
閱讀 2060·2021-11-23 09:51
閱讀 3353·2021-09-28 09:36
閱讀 1120·2021-09-08 09:35
閱讀 1758·2021-07-23 10:23
閱讀 3259·2019-08-30 15:54
閱讀 2998·2019-08-29 17:05
閱讀 438·2019-08-29 13:23
閱讀 1294·2019-08-28 17:51