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

輕松掌握 WebSocket API 的使用方法

這篇具有很好參考價(jià)值的文章主要介紹了輕松掌握 WebSocket API 的使用方法。希望對大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

輕松掌握 WebSocket API 的使用方法,軟件測試,websocket,網(wǎng)絡(luò)協(xié)議,網(wǎng)絡(luò),軟件測試,功能測試,自動(dòng)化測試,程序人生

WebSocket API 詳解

WebSocket API 是 HTML5 標(biāo)準(zhǔn)化之后的一項(xiàng) API,它可用于建立客戶端和服務(wù)器之間的雙向通信連接。

輕松掌握 WebSocket API 的使用方法,軟件測試,websocket,網(wǎng)絡(luò)協(xié)議,網(wǎng)絡(luò),軟件測試,功能測試,自動(dòng)化測試,程序人生

WebSocket 構(gòu)造函數(shù)

用于創(chuàng)建并返回一個(gè) WebSocket 對象。

示例:

//創(chuàng)建WebSocket對象,并指定服務(wù)端地址
var ws = new WebSocket("ws://localhost:8080");

WebSocket.readyState

表示 WebSocket 連接的狀態(tài)。

示例:

if (ws.readyState === WebSocket.OPEN) {
    //connection is open
}

WebSocket.bufferedAmount

用于獲取 WebSocket 對象在發(fā)送緩沖區(qū)中的字節(jié)數(shù)。

示例:

var bufferedAmount = ws.bufferedAmount;

WebSocket.extensions

用于獲取 WebSocket 對象所用的擴(kuò)展。

示例:

var extensions = ws.extensions;

WebSocket.protocol

用于獲取 WebSocket 對象使用的協(xié)議。

示例:

var protocol = ws.protocol;

WebSocket.url

用于獲取 WebSocket 連接的 URL。

示例:

var url = ws.url;

WebSocket.send()

用于向服務(wù)器發(fā)送數(shù)據(jù)。

示例:

ws.send("Hello, server!");

WebSocket.close()

用于關(guān)閉 WebSocket 連接。

示例:

ws.close();

WebSocket.onerror

用于指定一個(gè)函數(shù)在 WebSocket 連接發(fā)生錯(cuò)誤時(shí)被調(diào)用。

示例:

ws.onerror = function(error) {
    console.log(error);
};

WebSocket.onopen

用于指定一個(gè)函數(shù)在WebSocket連接成功建立時(shí)被調(diào)用

示例:

ws.onopen = function() {
    console.log("Connection open!");
};

WebSocket.onclose

用于指定一個(gè)函數(shù)在 WebSocket 連接關(guān)閉時(shí)被調(diào)用。

示例:

ws.onclose = function() {
    console.log("Connection closed!");
};

WebSocket.onmessage

用于指定一個(gè)函數(shù)在 WebSocket 接收到服務(wù)器發(fā)送的數(shù)據(jù)時(shí)被調(diào)用。

示例:

ws.onmessage = function(event) {
    console.log("Data received: " + event.data);
};

以上就是WebSocket對象的所有API以及相應(yīng)的示例。

前端實(shí)踐 WebSocket

Nodejs 起一個(gè) WebSocket 服務(wù)

我們需要使用 Nodejs 去起一個(gè) WebSocket 服務(wù),具體代碼如下:

 // 引入nodejs-websocket
const ws = require('nodejs-websocket');
// 定義監(jiān)聽的host地址跟port端口
const HOST = '127.0.0.1'
const PORT = 3001;
// 創(chuàng)建ws服務(wù)
const service = ws.createServer((conn) => {
  conn.on('text', (message) => {
    // 當(dāng)收到消息的時(shí)候就開始定時(shí)推送
    console.log('message', message);
    setInterval(() => {
      // 隨機(jī)推送message里的內(nèi)容
      conn.sendText(`Now is ${new Date().getTime()}`);
    }, 1 * 1000);
  });
}).listen(PORT, HOST, () => {
  console.log('service---success');
});

頁面編寫

我們需要?jiǎng)?chuàng)建一個(gè) index.html,并寫入以下代碼:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <script>
    window.onload = () => {
        if ('WebSocket' in window) {
            // 創(chuàng)建websocket連接
            let ws = new WebSocket('ws://127.0.0.1:3001/websocket');
            // 成功連接的時(shí)候推送一條消息,此時(shí)服務(wù)端就可以開始推送數(shù)據(jù)了
            ws.onopen = () => {
                console.log('websocket success---');
                ws.send('success');
            }
            ws.onmessage = (message) => {
                let data = message.data;
                console.log('get websocket message---', data);
            }
            ws.onerror = () => {
                console.error('websocket fail');
            }
        } else {
            console.error('dont support websocket');
        };
    };
</script>

</head>
<body>
  
</body>
</html>

啟動(dòng)頁面

在 index.html 右鍵,并打開此文件:

輕松掌握 WebSocket API 的使用方法,軟件測試,websocket,網(wǎng)絡(luò)協(xié)議,網(wǎng)絡(luò),軟件測試,功能測試,自動(dòng)化測試,程序人生

查看效果

可以看到后端先接收到前端的信息,open 建立成功:

輕松掌握 WebSocket API 的使用方法,軟件測試,websocket,網(wǎng)絡(luò)協(xié)議,網(wǎng)絡(luò),軟件測試,功能測試,自動(dòng)化測試,程序人生

然后建立連接后,后端一直在為前端輸出信息:

輕松掌握 WebSocket API 的使用方法,軟件測試,websocket,網(wǎng)絡(luò)協(xié)議,網(wǎng)絡(luò),軟件測試,功能測試,自動(dòng)化測試,程序人生

調(diào)試 WebSocket 服務(wù)

如果你正在編寫 WebSocket 服務(wù)并需要進(jìn)行調(diào)試,可以使用 Apifox 來調(diào)試 WebSocket 服務(wù)~

谷歌插件

Apifox 有 Web端 和 客戶端,如果你使用的是 Web端,想要調(diào)試本地服務(wù),需要安裝 Apifox 的 谷歌插件。

下載地址:Apifox 谷歌瀏覽器插件。

輕松掌握 WebSocket API 的使用方法,軟件測試,websocket,網(wǎng)絡(luò)協(xié)議,網(wǎng)絡(luò),軟件測試,功能測試,自動(dòng)化測試,程序人生

新建 WebSocket 請求

WebSocket 是客戶端和服務(wù)端之間的長鏈接,因此你需要在 Apifox 中創(chuàng)建一個(gè) WebSocket 請求,以便跳轉(zhuǎn)到 Apifox 界面并填寫相應(yīng)的請求信息

  • 點(diǎn)擊創(chuàng)建按鈕
  • 填入 WebSocket 服務(wù)的地址
  • 可以選擇填寫 Message 和 Params

輕松掌握 WebSocket API 的使用方法,軟件測試,websocket,網(wǎng)絡(luò)協(xié)議,網(wǎng)絡(luò),軟件測試,功能測試,自動(dòng)化測試,程序人生

Message 和 Params

Message

在 Message 中,你可以填寫要傳遞到服務(wù)端的信息。服務(wù)端將接收你發(fā)送的信息。

輕松掌握 WebSocket API 的使用方法,軟件測試,websocket,網(wǎng)絡(luò)協(xié)議,網(wǎng)絡(luò),軟件測試,功能測試,自動(dòng)化測試,程序人生

Params

在傳輸過程中,你也可以攜帶參數(shù),可以通過在地址上添加查詢參數(shù)完成,可以攜帶的數(shù)據(jù)類型包括:

  • string
  • integer
  • number
  • array

輕松掌握 WebSocket API 的使用方法,軟件測試,websocket,網(wǎng)絡(luò)協(xié)議,網(wǎng)絡(luò),軟件測試,功能測試,自動(dòng)化測試,程序人生

保存請求

寫完所需信息之后,可以點(diǎn)擊 保存按鈕,進(jìn)行保存,方便下次可繼續(xù)調(diào)用。

輕松掌握 WebSocket API 的使用方法,軟件測試,websocket,網(wǎng)絡(luò)協(xié)議,網(wǎng)絡(luò),軟件測試,功能測試,自動(dòng)化測試,程序人生

連接、發(fā)送 WebSocket 請求

連接 WebSocket 服務(wù)

我們想要跟服務(wù)端進(jìn)行 WebSocket 通信,就需要先建立一個(gè) WebSocket 連接,我們只需要點(diǎn)擊 連接 按鈕。

輕松掌握 WebSocket API 的使用方法,軟件測試,websocket,網(wǎng)絡(luò)協(xié)議,網(wǎng)絡(luò),軟件測試,功能測試,自動(dòng)化測試,程序人生

連接成功之后,Apifox 有成功的提示:

輕松掌握 WebSocket API 的使用方法,軟件測試,websocket,網(wǎng)絡(luò)協(xié)議,網(wǎng)絡(luò),軟件測試,功能測試,自動(dòng)化測試,程序人生

服務(wù)端那邊也會(huì)因?yàn)檫B接成功,而做出響應(yīng)。

發(fā)送 WebSocket 請求

接著我們就可以跟服務(wù)端進(jìn)行 WebSocket 通信了。

我們可以使用 Apifox 點(diǎn)擊發(fā)送按鈕向服務(wù)端進(jìn)行發(fā)送 Message、Params。

輕松掌握 WebSocket API 的使用方法,軟件測試,websocket,網(wǎng)絡(luò)協(xié)議,網(wǎng)絡(luò),軟件測試,功能測試,自動(dòng)化測試,程序人生

與 WebSocket 服務(wù)通信

發(fā)送之后,服務(wù)端也可以向客戶端發(fā)送信息,例如我這里,我設(shè)置服務(wù)端每秒向客戶端發(fā)送當(dāng)時(shí)的時(shí)間戳~

這就是 Apifox 的 WebSocket 功能,非常方便。

輕松掌握 WebSocket API 的使用方法,軟件測試,websocket,網(wǎng)絡(luò)協(xié)議,網(wǎng)絡(luò),軟件測試,功能測試,自動(dòng)化測試,程序人生

最后感謝每一個(gè)認(rèn)真閱讀我文章的人,禮尚往來總是要有的,雖然不是什么很值錢的東西,如果你用得到的話可以直接拿走:

輕松掌握 WebSocket API 的使用方法,軟件測試,websocket,網(wǎng)絡(luò)協(xié)議,網(wǎng)絡(luò),軟件測試,功能測試,自動(dòng)化測試,程序人生

這些資料,對于【軟件測試】的朋友來說應(yīng)該是最全面最完整的備戰(zhàn)倉庫,這個(gè)倉庫也陪伴上萬個(gè)測試工程師們走過最艱難的路程,希望也能幫助到你!

輕松掌握 WebSocket API 的使用方法,軟件測試,websocket,網(wǎng)絡(luò)協(xié)議,網(wǎng)絡(luò),軟件測試,功能測試,自動(dòng)化測試,程序人生文章來源地址http://www.zghlxwxcb.cn/news/detail-781410.html

到了這里,關(guān)于輕松掌握 WebSocket API 的使用方法的文章就介紹完了。如果您還想了解更多內(nèi)容,請?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

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

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

相關(guān)文章

  • WebSocket的使用方法(JS前端)

    先來一個(gè)常用例子 封裝的代碼 上面的代碼就夠用,也可以查看我封裝好的 WebSocket 代碼(包括心跳機(jī)制):點(diǎn)擊查看 下面詳細(xì)說明常用的屬性和方法 更全面的官網(wǎng)的文檔可以去這里看:點(diǎn)擊查看 下面是我總結(jié)的內(nèi)容 WebSocket WebSocket 對象提供了用于創(chuàng)建和管理 WebSocket 連接,

    2024年02月02日
    瀏覽(31)
  • C#程序設(shè)計(jì)——Windows應(yīng)用程序開發(fā),1、初步掌握Windows應(yīng)用程序的設(shè)計(jì)方法。2、掌握常用窗體控件的使用方法。

    C#程序設(shè)計(jì)——Windows應(yīng)用程序開發(fā),1、初步掌握Windows應(yīng)用程序的設(shè)計(jì)方法。2、掌握常用窗體控件的使用方法。

    初步掌握Windows應(yīng)用程序的設(shè)計(jì)方法。 掌握常用窗體控件的使用方法。 1、設(shè)計(jì)一個(gè)Windows應(yīng)用程序,創(chuàng)建一個(gè)用于添加學(xué)生個(gè)人基本信息的窗體,窗體下方法同時(shí)滾動(dòng)信息“天行健,君子以自強(qiáng)不息!”。 ? 要示如下: 如圖1所示,設(shè)計(jì)窗體界面控件的布局 圖1 學(xué)生信息管理

    2024年02月10日
    瀏覽(39)
  • Unity中使用WebSocket (ws://)的方法

    Unity中使用WebSocket (ws://)的方法

    WebSocket使得客戶端和服務(wù)器之間的數(shù)據(jù)交換變得更加簡單,允許服務(wù)端主動(dòng)向客戶端推送數(shù)據(jù)。在WebSocket API中,瀏覽器和服務(wù)器只需要完成一次握手,兩者之間就直接可以創(chuàng)建持久性的連接,并進(jìn)行雙向數(shù)據(jù)傳輸。 其實(shí)從歷史上來講,websocket是為了克服http無法雙向通信而引

    2024年02月09日
    瀏覽(25)
  • 即時(shí)通信的方法和webSocket的具體使用

    即時(shí)通信的方法和webSocket的具體使用

    之前遇到過需要即時(shí)通訊的場景,剛開始使用的是通過輪詢的方式,定時(shí)器3秒向服務(wù)器請求一次數(shù)據(jù),后面發(fā)現(xiàn)如果在手機(jī)端長時(shí)間打開使用此功能的頁面,可能會(huì)發(fā)生手機(jī)發(fā)熱,甚至卡頓的現(xiàn)象。最后改用webSocket,可以實(shí)現(xiàn)全雙工通信,讓服務(wù)器主動(dòng)向客戶端發(fā)送請求。

    2024年02月15日
    瀏覽(23)
  • 五分鐘快速掌握Python中dict(字典)的詳細(xì)使用方法

    五分鐘快速掌握Python中dict(字典)的詳細(xì)使用方法

    目錄 概念: dict的定義格式: dict的使用方法: 定義空字典的兩種方法: dict.clear: ?copy: copy:淺拷貝 deepcopy:深拷貝 get: ?items: ?keys: ?popitem: ?setdefault: ?update: ?values: dict----dictionary ?字典: 根據(jù)去獲取內(nèi)容 不能重復(fù) 必須是不可變的數(shù)據(jù)類型

    2024年02月12日
    瀏覽(27)
  • 掌握AI智能化辦公:ChatGPT使用方法與技巧指南

    掌握AI智能化辦公:ChatGPT使用方法與技巧指南

    ?? 個(gè)人網(wǎng)站:【 海擁】【神級代碼資源網(wǎng)站】【辦公神器】 ?? 基于Web端打造的:??輕量化工具創(chuàng)作平臺(tái) ?? 想尋找共同學(xué)習(xí)交流的小伙伴,請點(diǎn)擊【全棧技術(shù)交流群】 ChatGPT簡介 ChatGPT是基于GPT(Generative Pre-trained Transformer)模型的一種應(yīng)用。GPT模型通過大規(guī)模的預(yù)訓(xùn)練數(shù)據(jù)

    2024年02月05日
    瀏覽(56)
  • Python-Websocket的介紹及使用方法

    Python-Websocket的介紹及使用方法

    ?????? 哈嘍!大家好,我是【太陽打傘】,一位熱愛分享各種技術(shù)的博主!?????? ?【太陽打傘】的創(chuàng)作宗旨:每一條命令都親自執(zhí)行過,每一行代碼都實(shí)際運(yùn)行過,每一種方法都真實(shí)實(shí)踐過,每一篇文章都良心制作過。??? ?【太陽打傘】的博客中所有涉及命令、

    2023年04月15日
    瀏覽(19)
  • 擴(kuò)展Nginx的無限可能:掌握常見擴(kuò)展模塊和第三方插件的使用方法

    Nginx是一款高性能的開源Web服務(wù)器和反向代理服務(wù)器。它具有模塊化的架構(gòu),可以通過擴(kuò)展模塊和插件來增強(qiáng)其功能。在本文中,我將圍繞Nginx的擴(kuò)展模塊和插件進(jìn)行講解,并提供一些常見的擴(kuò)展模塊和第三方插件的示例。 Nginx的擴(kuò)展模塊是編譯到Nginx中的可選組件,可以通過

    2024年02月08日
    瀏覽(29)
  • 48掌握私有云平臺(tái) OpenStack 的基本服務(wù)和使用方法,包括 Nova、Glance

    48掌握私有云平臺(tái) OpenStack 的基本服務(wù)和使用方法,包括 Nova、Glance

    Nova 是 OpenStack 的計(jì)算組件,用于管理和調(diào)度計(jì)算資源。它可以管理虛擬機(jī)實(shí)例、安全組、彈性 IP、浮動(dòng) IP 等資源。 nova-api nova-api 是 Nova 的 API 服務(wù),它接收來自用戶和其他服務(wù)的 API 請求,并將它們轉(zhuǎn)換為后臺(tái)計(jì)算資源管理系統(tǒng)的操作。 nova-scheduler nova-scheduler 是 Nova 的調(diào)度

    2024年02月07日
    瀏覽(49)
  • Android中okhttp的websocket的詳細(xì)使用方法(加斷線重連)

    介紹之類的就不多講了,懶得講也未必有別人整理的清晰,直接上代碼 使用:

    2024年02月15日
    瀏覽(26)

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

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

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

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

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包