亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

websocket+sockjs+stompjs詳解及實例代碼

2024-08-26 00:21:10
字體:
來源:轉載
供稿:網友

最近有項目需求要用到websocket,剛開始以為很簡單,但是隨著遇到問題,深入了解,才知道websocket并不是想象中的那么簡單,這篇文章主要是考慮websocket在客戶端的使用。

1.http與websocket

http超文本傳輸協議,大家都非常熟悉,http有1.0、1.1、 2.0幾個版本,從http1.1起,默認都開啟了Keep-Alive,保持連接持續性,簡單地說,當一個網頁打開完成后,客戶端和服務器之間用于傳輸http數據的TCP連接不會關閉,如果客戶端再次訪問這個服務器上的網頁,會繼續使用這一條已經建立的連接,這樣就降低了資源的消耗優化性能,但是Keep-Alive也是有時間限制的,還有一個客戶端只能主動發起請求才能獲取返回數據,并不能主動接收后臺推送的數據,websocket便應運而生。

websocket 是html5新增加特性之一,目的是瀏覽器與服務端建立全雙工的通信方式,解決 http 請求-響應帶來過多的資源消耗,同時對特殊場景應用提供了全新的實現方式,比如聊天、股票交易、游戲等對對實時性要求較高的行業領域。

http與websocket都是基于TCP(傳輸控制協議)的,websocket可以看做是對http協議的一個補充

2.SockJs

SockJS是一個JavaScript庫,為了應對許多瀏覽器不支持WebSocket協議的問題,設計了備選SockJs。SockJS 是 WebSocket 技術的一種模擬。SockJS會盡可能對應 WebSocket API,但如果WebSocket 技術不可用的話,會自動降為輪詢的方式。

3.Stompjs

STOMP—— Simple Text Oriented Message Protocol——面向消息的簡單文本協議。

SockJS 為 WebSocket 提供了 備選方案。但無論哪種場景,對于實際應用來說,這種通信形式層級過低。 STOMP協議,來為瀏覽器 和 server 間的 通信增加適當的消息語義。

4.WebSocket、SockJs、STOMP三者關系

簡而言之,WebSocket 是底層協議,SockJS 是WebSocket 的備選方案,也是底層協議,而 STOMP 是基于 WebSocket(SockJS)的上層協議。

1、HTTP協議解決了 web 瀏覽器發起請求以及 web 服務器響應請求的細節,假設 HTTP 協議 并不存在,只能使用 TCP 套接字來 編寫 web 應用。

2、直接使用 WebSocket(SockJS) 就很類似于 使用 TCP 套接字來編寫 web 應用,因為沒有高層協議,就需要我們定義應用間所發送消息的語義,還需要確保連接的兩端都能遵循這些語義;

3、同HTTP在TCP 套接字上添加請求-響應模型層一樣,STOMP在WebSocket 之上提供了一個基于幀的線路格式層,用來定義消息語義;

5.使用實例

安裝 sockjs-client、stompjs;在這兒要注意一下,我在"stompjs": "^2.3.3"這個版本發現,引入stompjs會報一個net模塊找不到,需要在stompjs模塊根目錄下執行npm install,這個是個奇葩的問題。

引入模塊:

import SockJS from 'sockjs-client';import Stomp from 'stompjs';// 連接函數let number = 1;function reconnect(socketUrl) {    let url = `${BASE_URL}/ws/sdfpoint`; //連接地址    // 建立連接對象(還未發起連接)    let socket = new SockJS(url);    // 獲取 STOMP 子協議的客戶端對象    let stompClient = Stomp.over(socket);    // 向服務器發起websocket連接并發送CONNECT幀    stompClient.connect(        {},//可添加客戶端的認證信息        function connectCallback (){//連接成功的回調函數            //訂閱頻道            stompClient.subscribe('/topic/display/control', function(data){                if (data) {                    console.log('subscribe data',data);                }            })        },        function errorCallBack(error){          //連接失敗時再次調用函數            number += 1;            if(number<=10){                reconnect(url);            }            console.log('error',error);        }    )     }

總結:websocket 的實現客戶端看起來比較簡單,但是需要與后臺進行很好的配合和調試才能達到最佳效果。通過SockJS、Stomp來進行瀏覽器兼容,增加消息語義,增強了可用性。要徹底搞懂websocket,我們還需要深入了解一些底層的原理以及相關的知識。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩精品福利网站| 精品无人国产偷自产在线| 国产成人午夜视频网址| 亚洲欧美自拍一区| 国产精品日韩一区| 国产精品扒开腿做爽爽爽男男| 韩国精品久久久999| 欧美性极品xxxx娇小| 全亚洲最色的网站在线观看| 国产精品女主播视频| 欧美在线视频免费播放| 国产亚洲精品高潮| 亚洲视频第一页| 欧美激情精品在线| 国产欧美va欧美va香蕉在线| 国产精品视频资源| 国产精品自拍偷拍视频| 爽爽爽爽爽爽爽成人免费观看| 中文国产成人精品久久一| 欧美亚洲视频在线看网址| 国产精品一区二区电影| 亚洲精品电影在线观看| 欧美激情视频一区| 国产精品爽爽ⅴa在线观看| 欧美激情一级欧美精品| 亚洲精品大尺度| 9.1国产丝袜在线观看| 亚洲精品国产精品久久清纯直播| 国产国语videosex另类| 中文字幕精品—区二区| 欧美日韩国产一区二区三区| 亚洲va久久久噜噜噜| 97超碰国产精品女人人人爽| 亚洲欧美激情另类校园| 91精品视频网站| 国产精品一区二区av影院萌芽| 日本久久久a级免费| 欧美日韩国产影院| 日本精品免费一区二区三区| 午夜精品国产精品大乳美女| 九九热精品在线| 精品调教chinesegay| 欧美午夜片欧美片在线观看| 岛国精品视频在线播放| 亚洲电影在线观看| 97在线免费视频| 亚洲综合第一页| 91高潮精品免费porn| 成人xvideos免费视频| 国产精品视频专区| 精品国产鲁一鲁一区二区张丽| 亚洲黄色片网站| 狠狠综合久久av一区二区小说| 欧美天堂在线观看| 国产精品v日韩精品| 国产精品久久久久久婷婷天堂| 欧美美女操人视频| 欧美精品电影免费在线观看| 日韩成人黄色av| 日韩精品免费在线| 免费成人高清视频| 久久这里只有精品99| 91老司机在线| 久久精品国产成人精品| 亚洲第一偷拍网| 91国产精品视频在线| 国产精品27p| 国产91成人在在线播放| 久久久久久97| 亚洲人午夜精品| 日韩激情视频在线| 亚洲护士老师的毛茸茸最新章节| 欧美人与物videos| 亚洲美腿欧美激情另类| 97不卡在线视频| 国产精品成人v| 欧美黄色成人网| 国产婷婷97碰碰久久人人蜜臀| 日本成人精品在线| 欧美日韩国产一区二区| 91麻豆国产语对白在线观看| 中文.日本.精品| 亚洲欧美日韩中文在线制服| 91精品久久久久久久久久久久久久| 亚洲精品自在久久| 国产精自产拍久久久久久| 亚洲精品欧美日韩| 91成品人片a无限观看| 精品国产91久久久久久老师| 日韩少妇与小伙激情| 午夜精品免费视频| 久久久国产精品亚洲一区| 美女黄色丝袜一区| 操日韩av在线电影| 亚洲人成77777在线观看网| 欧美性在线观看| 欧美日韩亚洲一区二| 日韩欧美在线看| 欧美激情中文字幕在线| 911国产网站尤物在线观看| 97精品欧美一区二区三区| 欧美综合一区第一页| 国产成人精品亚洲精品| 国产精品主播视频| 久久久久久久久国产精品| 在线播放日韩欧美| 国产欧美日韩免费看aⅴ视频| 国产综合在线视频| 久久久国产精品一区| 日本亚洲欧美成人| 国产精品免费久久久久久| 欧美精品成人91久久久久久久| 欧美国产日韩xxxxx| 欧美高跟鞋交xxxxhd| 国产精品久久久久999| 国产精品亚洲激情| 亚洲白虎美女被爆操| 欧美成人精品h版在线观看| 九九精品在线视频| 欧美肥婆姓交大片| 亚洲自拍高清视频网站| 国产精品中文在线| 456国产精品| 亚洲免费视频观看| 久热精品视频在线| 欧美国产日韩中文字幕在线| 国产美女高潮久久白浆| 日本不卡视频在线播放| 深夜精品寂寞黄网站在线观看| 亚洲精品720p| 中文字幕免费精品一区| 性欧美办公室18xxxxhd| 91牛牛免费视频| 亚洲最新av在线网站| 精品国产自在精品国产浪潮| 伊人一区二区三区久久精品| 日韩免费看的电影电视剧大全| 国产精品27p| 亚洲精品久久久久国产| 久久亚洲电影天堂| 精品国模在线视频| 日本成人激情视频| 国产在线精品播放| 欧美激情性做爰免费视频| 亚洲精品国产拍免费91在线| 国产精品久久久久久av福利| 欧美日韩成人免费| 欧美高清第一页| 亚洲日本欧美中文幕| 亚洲第一黄色网| 日本成人免费在线| 欧美三级免费观看| www.色综合| 国产精品av在线播放| 亚洲午夜精品久久久久久性色| 欧美亚洲另类在线| 日韩免费观看视频| 色偷偷亚洲男人天堂| 日韩欧美综合在线视频| 国产ts人妖一区二区三区| 久久99国产综合精品女同| 九九九热精品免费视频观看网站| 欧美午夜激情视频| 18性欧美xxxⅹ性满足|