国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

SpringBoot集成WebSocket實現(xiàn)客戶端與服務(wù)端長連接通信

這篇具有很好參考價值的文章主要介紹了SpringBoot集成WebSocket實現(xiàn)客戶端與服務(wù)端長連接通信。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

場景:
1、WebSocket協(xié)議是用于前后端長連接交互的技術(shù),此技術(shù)多用于交互不斷開的場景。特點是連接不間斷、更輕量,只有在關(guān)閉瀏覽器窗口、或者關(guān)閉瀏覽器、或主動close,當(dāng)前會話對象才會關(guān)閉。
2、相較于 Http/Https?通信只能由客戶端主動發(fā)起請求,而 Socket?通信不僅能由客戶端主動發(fā)起請求、服務(wù)端也可能主動給客戶端推送消息

這里只是簡單的記錄一下使用方式

一、服務(wù)端

1、導(dǎo)入 websocket 依賴

		<!-- Socket -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-websocket</artifactId>
        </dependency>

2、配置 WebSocket 通信協(xié)議標(biāo)準(zhǔn)(服務(wù)端點導(dǎo)出)對象

    @Bean
    public ServerEndpointExporter serverEndpointExporter() {
        return new ServerEndpointExporter();
    }

說明:
如果沒有配置 WebSocket 通信協(xié)議標(biāo)準(zhǔn)對象,可能會導(dǎo)致如下錯誤:

錯誤一:
VM105:1 WebSocket connection to 'ws://xxx:7002' failed: Error during WebSocket handshake: Unexpected response code: 404

錯誤二:
This request has been blocked; this endpoint must be available over WSS.

錯誤三:
VM78:1 WebSocket connection to 'wss://xxx:7002' failed: Error in connection establishment: net::ERR_SSL_PROTOCOL_ERROR

錯誤四(沒有攜帶token或密鑰):
VM78:1 WebSocket connection to 'wss://xxx:7002' failed: Error in connection establishment: net::ERR_SSL_PROTOCOL_ERROR

3、服務(wù)端的四個注解方法,對應(yīng)觸發(fā)事件

@OnOpen:連接成功交互初始化
@OnMessage:消息事件
@OnClose:關(guān)閉事件
@OnError:異常事件

4、websocket 事件服務(wù)類,可以理解為Restful Api的映射類(controller)

@Slf4j
@Component
@ServerEndpoint("/websocket/msg/{userId}")
public class WsMessageService {

    //與某個客戶端的連接會話,通過此會話對象給客戶端發(fā)送數(shù)據(jù)
    private Session session;

    //concurrent包的線程安全Set,用來存放每個客戶端對應(yīng)的WebSocket對象。
    //注:泛型是當(dāng)前類名
    //private static Set<WsMessageService> webSockets = new CopyOnWriteArraySet<>();
    private static Map<String, WsMessageService> webSocketsBeanMap = new ConcurrentHashMap<>();

    //用來保存在線連接數(shù)
    //private static Map<String, Session> sessionPool = new HashMap<>();

    //每次連接都是一個新的會話對象,線程安全的
    String userId;


    @OnOpen
    public void onOpen(Session session, @PathParam(value = "userId") String userId) {
        this.session = session;
        this.userId = userId;
        webSocketsBeanMap.put(userId, this);
        log.info("OnOpen連接成功,userId:{},當(dāng)前在線人數(shù):{}", userId, this.getOnLineCount());
    }

    @OnMessage
    public void onMessage(String message) throws IOException {
        Session session = webSocketsBeanMap.get(this.userId).session;
        if (ObjectUtil.isNull(session) || !session.isOpen()) {
            return;
        }
        log.info("收到客戶端的消息:" + message);
        this.session.getBasicRemote().sendText(String.valueOf(this.getOnLineCount()));
    }

    @OnClose
    public void onClose() throws IOException {
        log.info("會話關(guān)閉,關(guān)閉會話的用戶Id為:{}", this.userId);
        webSocketsBeanMap.remove(this.userId);
        log.info("當(dāng)前在線人數(shù):{}", this.getOnLineCount());
    }

    @OnError
    public void onError(Session session, Throwable error) {
        log.error("連接錯誤:" + error.getMessage());
        error.printStackTrace();
    }


    /**
     * <p>返回在線人數(shù)</p>
     *
     * @author hkl
     * @date 2023/2/16
     */
    private int getOnLineCount() {
        return webSocketsBeanMap.size();
    }

}

?到這里服務(wù)端demo已經(jīng)完成,可以使用瀏覽器、HTML頁面、Apipost測試

二、測試驗證

連接語法:ws://IP地址:端口號

1、使用 Apipost?工具測試

【1】下載安裝 Apipost
springboot websocket客戶端,TCP\HTTP、WebSocket通信協(xié)議,websocket,網(wǎng)絡(luò)協(xié)議

【2】輸入訪問地址、連接、發(fā)送消息,如下
springboot websocket客戶端,TCP\HTTP、WebSocket通信協(xié)議,websocket,網(wǎng)絡(luò)協(xié)議

2、用瀏覽器測試
第1步:var ws = new WebSocket("ws://localhost:7000/mpj/websocket/1");
第2步:console.log("連接狀態(tài):", ws.readyState);

連接狀態(tài)說明:
0:CONNECTING,表示正在連接。
1:OPEN,表示連接成功,可以通信了。
2:CLOSING,表示連接正在關(guān)閉。
3:CLOSED,表示連接已經(jīng)關(guān)閉,或者打開連接失敗

第3步:ws.send("hello");?

示例如下:
springboot websocket客戶端,TCP\HTTP、WebSocket通信協(xié)議,websocket,網(wǎng)絡(luò)協(xié)議

?服務(wù)端收到消息:
springboot websocket客戶端,TCP\HTTP、WebSocket通信協(xié)議,websocket,網(wǎng)絡(luò)協(xié)議

3、使用 html?頁面編寫js腳本測試

<!DOCTYPE html>
<html lang="zh-cn">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"content="width=device-width, initial-scale=1.0">
    <title>WebSocket測試</title>
    <script>
        function initWebSocket(wsUri) {
            var websocket = new WebSocket(wsUri);
            websocket.onopen = function(evt) {
                console.log('連接建立中... '+wsUri);
            };
            websocket.onclose = function(evt) {
                console.log('連接關(guān)閉中...', evt);
            };
            websocket.onmessage = function(evt) {
                console.log('收到來自服務(wù)端的消息:', evt.data);
            };
            websocket.onerror = function(evt) {
                console.log('發(fā)生錯誤...', evt);
            };
            return websocket;
        }
    
        //在此配置 websocket 的地址
        var websocket = initWebSocket("ws://localhost:6000/mpj/websocket/msg/1");
        var msg, i = 0;
        var loop = setInterval(function(){
            msg = "Hello " +(i++);
            if(websocket.readyState == WebSocket.OPEN) {
                websocket.send(msg);
                console.log('已發(fā)送消息:' +msg);
            } else{
                clearInterval(loop);
                console.log('連接已關(guān)閉,拜拜~');
            }
        }, 3000);
    </script>
</head>
<body>請按 F12 打開控制臺查看消息
</body>
</html>

運行如下:
springboot websocket客戶端,TCP\HTTP、WebSocket通信協(xié)議,websocket,網(wǎng)絡(luò)協(xié)議

?springboot websocket客戶端,TCP\HTTP、WebSocket通信協(xié)議,websocket,網(wǎng)絡(luò)協(xié)議文章來源地址http://www.zghlxwxcb.cn/news/detail-780779.html

到了這里,關(guān)于SpringBoot集成WebSocket實現(xiàn)客戶端與服務(wù)端長連接通信的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進(jìn)行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • 【Java】SpringBoot快速整合WebSocket實現(xiàn)客戶端服務(wù)端相互推送信息

    【Java】SpringBoot快速整合WebSocket實現(xiàn)客戶端服務(wù)端相互推送信息

    目錄 什么是webSocket? webSocket可以用來做什么? WebSocket操作類 一:測試客戶端向服務(wù)端推送消息 1.啟動SpringBoot項目 2.打開網(wǎng)站 3.進(jìn)行測試消息推送 4.后端進(jìn)行查看測試結(jié)果 二:測試服務(wù)端向客戶端推送消息 1.接口代碼 2.使用postman進(jìn)行調(diào)用 3.查看測試結(jié)果 ????????WebSocke

    2024年01月20日
    瀏覽(37)
  • Java:SpringBoot整合WebSocket實現(xiàn)服務(wù)端向客戶端推送消息

    Java:SpringBoot整合WebSocket實現(xiàn)服務(wù)端向客戶端推送消息

    思路: 后端通過websocket向前端推送消息,前端統(tǒng)一使用http協(xié)議接口向后端發(fā)送數(shù)據(jù) 本文僅放一部分重要的代碼,完整代碼可參看github倉庫 websocket 前端測試 :http://www.easyswoole.com/wstool.html 依賴 項目目錄 完整依賴 配置 WebSocketServer.java 前端頁面 websocket.html 前端邏輯 index.js 參

    2024年02月04日
    瀏覽(29)
  • Springboot 集成WebSocket作為客戶端,含重連接功能,開箱即用

    使用演示 只需要init后調(diào)用sendMessage方法即可,做到開箱即用。內(nèi)部封裝了失敗重連接、斷線重連接等功能。 基于Springboot工程 引入websocket依賴 開箱即用的工具類

    2024年02月04日
    瀏覽(36)
  • springboot集成webstock實戰(zhàn):服務(wù)端數(shù)據(jù)推送數(shù)據(jù)到客戶端實現(xiàn)實時刷新

    springboot集成webstock實戰(zhàn):服務(wù)端數(shù)據(jù)推送數(shù)據(jù)到客戶端實現(xiàn)實時刷新

    ????之前介紹過springboot集成webstock方式,具體參考: springboot集成websocket實戰(zhàn):站內(nèi)消息實時推送 這里補(bǔ)充另外一個使用webstock的場景,方便其他同學(xué)理解和使用,廢話不多說了,直接開始!簡單介紹一下業(yè)務(wù)場景: ????現(xiàn)在有一個投票活動,活動詳情中會顯示投票活動的參與人數(shù)、訪

    2024年02月08日
    瀏覽(48)
  • 二、springboot集成CAS客戶端實現(xiàn)單點登錄

    pom中引入依賴 yml中添加cas配置 讀取CAS相關(guān)配置 cas配置類 單點登錄接口demo 訪問loingCas接口時,若未在CASserver登錄,則會被攔截跳轉(zhuǎn)到CAS的登陸頁面,登陸成功后放行繼續(xù)訪問loginCas接口

    2024年02月15日
    瀏覽(23)
  • Java實現(xiàn)WebSocket客戶端和服務(wù)端(簡單版)

    Java實現(xiàn)WebSocket客戶端和服務(wù)端(簡單版)

    天行健,君子以自強(qiáng)不息;地勢坤,君子以厚德載物。 每個人都有惰性,但不斷學(xué)習(xí)是好好生活的根本,共勉! 文章均為學(xué)習(xí)整理筆記,分享記錄為主,如有錯誤請指正,共同學(xué)習(xí)進(jìn)步。 寫在前面: WebSocket是一種在單個TCP連接上進(jìn)行全雙工通信的協(xié)議。 WebSocket通信協(xié)議于

    2024年02月08日
    瀏覽(35)
  • C++實現(xiàn)WebSocket通信(服務(wù)端和客戶端)

    C++實現(xiàn)WebSocket通信(服務(wù)端和客戶端)

    天行健,君子以自強(qiáng)不息;地勢坤,君子以厚德載物。 每個人都有惰性,但不斷學(xué)習(xí)是好好生活的根本,共勉! 文章均為學(xué)習(xí)整理筆記,分享記錄為主,如有錯誤請指正,共同學(xué)習(xí)進(jìn)步。 這里單純是個人總結(jié),如需更官方更準(zhǔn)確的websocket介紹可百度 websocket是一種即時通訊協(xié)

    2024年02月09日
    瀏覽(19)
  • Python3實現(xiàn)WebSocket服務(wù)端與客戶端通信

    Python3實現(xiàn)WebSocket服務(wù)端與客戶端通信 WebSocket是一種在單個TCP連接上進(jìn)行全雙工通信的協(xié)議。WebSocket通信更加輕便、高效,比傳統(tǒng)的HTTP通信更省流量和更快速,因此在Web應(yīng)用領(lǐng)域越來越受歡迎。Python 3提供了內(nèi)置的websocket庫,可以方便地實現(xiàn)WebSocket服務(wù)端和客戶端的通信。

    2024年02月12日
    瀏覽(22)
  • C++實現(xiàn)websocket服務(wù)端客戶端(基于boost,親測可行!)

    ?? 整篇文章基本參考了https://blog.csdn.net/jianghuan0122/article/details/123528907,文章記錄了如何在現(xiàn)有條件下實現(xiàn)該參考示例(參考示例存在報錯,并且參考示例沒有介紹環(huán)境安裝,正確源碼附于文末) ?? 自身環(huán)境:ubuntu18.04+gcc7.5.0+boost1.7,3 ??gcc或者g++一般都有,這里主要介紹

    2024年02月11日
    瀏覽(19)
  • WebSocket 詳解,以及用QWebSocket 實現(xiàn)服務(wù)端和客戶端(含代碼例子)

    WebSocket 詳解,以及用QWebSocket 實現(xiàn)服務(wù)端和客戶端(含代碼例子)

    目錄 前言: 1、WebSocket 誕生背景 2、WebSocket的特點: 3、 WebSocket 簡介 4、WebSocket 優(yōu)點 5、QWebSocket通訊—客戶端: 6、QWebSocket通訊—服務(wù)端: 前言: ????????要是對WebSocket 的基本知識都了解了,可以直接移步,實際如何使用這個類 (二) 用QWebSocket 實現(xiàn)服務(wù)端和客戶端(

    2024年02月16日
    瀏覽(53)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包