在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

鴻蒙開發(fā)網(wǎng)絡管理:ohos.net.webSocket WebSocket連接

jf_46214456 ? 來源:jf_46214456 ? 作者:jf_46214456 ? 2024-06-19 17:12 ? 次閱讀

WebSocket連接

說明: 本模塊首批接口從API version 6開始支持。后續(xù)版本的新增接口,采用上角標單獨標記接口的起始版本。

使用WebSocket建立服務器與客戶端的雙向連接,需要先通過[createWebSocket]方法創(chuàng)建[WebSocket]對象,然后通過[connect]方法連接到服務器。當連接成功后,客戶端會收到[open]事件的回調(diào),之后客戶端就可以通過[send]方法與服務器進行通信。當服務器發(fā)信息給客戶端時,客戶端會收到[message]事件的回調(diào)。當客戶端不要此連接時,可以通過調(diào)用[close]方法主動斷開連接,之后客戶端會收到[close]事件的回調(diào)。

若在上述任一過程中發(fā)生錯誤,客戶端會收到[error]事件的回調(diào)。

導入模塊

import webSocket from '@ohos.net.webSocket';

完整示例

import webSocket from '@ohos.net.webSocket';

var defaultIpAddress = "ws://";
let ws = webSocket.createWebSocket();
ws.on('open', (err, value) = > {
    console.log("on open, status:" + value['status'] + ", message:" + value['message']);
    // 當收到on('open')事件時,可以通過send()方法與服務器進行通信
    ws.send("Hello, server!", (err, value) = > {
        if (!err) {
            console.log("send success");
        } else {
            console.log("send fail, err:" + JSON.stringify(err));
        }
    });
});
ws.on('message', (err, value) = > {
    console.log("on message, message:" + value);
    // 當收到服務器的`bye`消息時(此消息字段僅為示意,具體字段需要與服務器協(xié)商),主動斷開連接
    if (value === 'bye') {
        ws.close((err, value) = > {
            if (!err) {
                console.log("close success");
            } else {
                console.log("close fail, err is " + JSON.stringify(err));
            }
        });
    }
});
ws.on('close', (err, value) = > {
    console.log("on close, code is " + value.code + ", reason is " + value.reason);
});
ws.on('error', (err) = > {
    console.log("on error, error:" + JSON.stringify(err));
});
ws.connect(defaultIpAddress, (err, value) = > {
    if (!err) {
        console.log("connect success");
    } else {
        console.log("connect fail, err:" + JSON.stringify(err));
    }
});

webSocket.createWebSocket

createWebSocket(): WebSocket

創(chuàng)建一個WebSocket,里面包括建立連接、關閉連接、發(fā)送數(shù)據(jù)和訂閱/取消訂閱WebSocket連接的打開事件、接收到服務器消息事件、關閉事件和錯誤事件。

系統(tǒng)能力 :SystemCapability.Communication.NetStack

返回值:

類型說明
[WebSocket]返回一個WebSocket對象,里面包括connect、send、close、on和off方法。

示例:

let ws = webSocket.createWebSocket();

WebSocket

在調(diào)用WebSocket的方法前,需要先通過[webSocket.createWebSocket]創(chuàng)建一個WebSocket。

connect

connect(url: string, callback: AsyncCallback): void

根據(jù)URL地址,建立一個WebSocket連接,使用callback方式作為異步方法。

需要權限 :ohos.permission.INTERNET

系統(tǒng)能力 :SystemCapability.Communication.NetStack

參數(shù)

參數(shù)名類型必填說明
urlstring建立WebSocket連接的URL地址。
callbackAsyncCallback回調(diào)函數(shù)。

示例:

let ws = webSocket.createWebSocket();
let url = "ws://"
ws.connect(url, (err, value) = > {
	if (!err) {
		console.log("connect success");
	} else {
		console.log("connect fail, err:" + JSON.stringify(err))
	}
});

connect

connect(url: string, options: WebSocketRequestOptions, callback: AsyncCallback): void

根據(jù)URL地址和header,建立一個WebSocket連接,使用callback方式作為異步方法。

需要權限 :ohos.permission.INTERNET

系統(tǒng)能力 :SystemCapability.Communication.NetStack

參數(shù):

參數(shù)名類型必填說明
urlstring建立WebSocket連接的URL地址。
optionsWebSocketRequestOptions參考[WebSocketRequestOptions]。
callbackAsyncCallback回調(diào)函數(shù)。

示例:

let ws = webSocket.createWebSocket();
let url = "ws://"
ws.connect(url, {
	header: {
		"key": "value",
		"key2": "value2"
	}
}, (err, value) = > {
	if (!err) {
		console.log("connect success");
	} else {
		console.log("connect fail, err:" + JSON.stringify(err))
	}
});

connect

connect(url: string, options?: WebSocketRequestOptions): Promise

根據(jù)URL地址和header,建立一個WebSocket連接,使用Promise方式作為異步方法。

需要權限 :ohos.permission.INTERNET

系統(tǒng)能力 :SystemCapability.Communication.NetStack

參數(shù):

參數(shù)名類型必填說明
urlstring建立WebSocket連接的URL地址。
optionsWebSocketRequestOptions參考[WebSocketRequestOptions]。

返回值:

類型說明
Promise以Promise形式返回建立連接的結果。

示例:

let ws = webSocket.createWebSocket();
let url = "ws://"
let promise = ws.connect(url);
promise.then((value) = > {
	console.log("connect success")
}).catch((err) = > {
	console.log("connect fail, error:" + JSON.stringify(err))
});

send

send(data: string | ArrayBuffer, callback: AsyncCallback): void

通過WebSocket連接發(fā)送數(shù)據(jù),使用callback方式作為異步方法。

需要權限 :ohos.permission.INTERNET

系統(tǒng)能力 :SystemCapability.Communication.NetStack

參數(shù):

參數(shù)名類型必填說明
datastringArrayBuffer 8+
callbackAsyncCallback回調(diào)函數(shù)。

示例:

let ws = webSocket.createWebSocket();
let url = "ws://"
ws.connect(url, (err, value) = > {
	ws.send("Hello, server!", (err, value) = > {
		if (!err) {
			console.log("send success");
		} else {
			console.log("send fail, err:" + JSON.stringify(err))
		}
	});
});

send

send(data: string | ArrayBuffer): Promise

通過WebSocket連接發(fā)送數(shù)據(jù),使用Promise方式作為異步方法。

需要權限 :ohos.permission.INTERNET

系統(tǒng)能力 :SystemCapability.Communication.NetStack

參數(shù):

參數(shù)名類型必填說明
datastringArrayBuffer 8+

返回值:

類型說明
Promise以Promise形式返回發(fā)送數(shù)據(jù)的結果。

示例:

let ws = webSocket.createWebSocket();
let url = "ws://"
ws.connect(url, (err, value) = > {
	let promise = ws.send("Hello, server!");
	promise.then((value) = > {
		console.log("send success")
	}).catch((err) = > {
		console.log("send fail, error:" + JSON.stringify(err))
	});
});

close

close(callback: AsyncCallback): void

關閉WebSocket連接,使用callback方式作為異步方法。

需要權限 :ohos.permission.INTERNET

系統(tǒng)能力 :SystemCapability.Communication.NetStack

參數(shù):

參數(shù)名類型必填說明
callbackAsyncCallback回調(diào)函數(shù)。

示例:

let ws = webSocket.createWebSocket();
let url = "ws://"
ws.close((err, value) = > {
	if (!err) {
		console.log("close success")
	} else {
		console.log("close fail, err is " + JSON.stringify(err))
	}
});

close

close(options: WebSocketCloseOptions, callback: AsyncCallback): void

根據(jù)可選參數(shù)code和reason,關閉WebSocket連接,使用callback方式作為異步方法。

需要權限 :ohos.permission.INTERNET

系統(tǒng)能力 :SystemCapability.Communication.NetStack

參數(shù):

參數(shù)名類型必填說明
optionsWebSocketCloseOptions參考[WebSocketCloseOptions]。
callbackAsyncCallback回調(diào)函數(shù)。

示例:

let ws = webSocket.createWebSocket();
let url = "ws://"
ws.close({
	code: 1000,
	reason: "your reason"
}, (err, value) = > {
	if (!err) {
		console.log("close success")
	} else {
		console.log("close fail, err is " + JSON.stringify(err))
	}
});

close

close(options?: WebSocketCloseOptions): Promise

根據(jù)可選參數(shù)code和reason,關閉WebSocket連接,使用Promise方式作為異步方法。

需要權限 :ohos.permission.INTERNET

系統(tǒng)能力 :SystemCapability.Communication.NetStack

參數(shù):

參數(shù)名類型必填說明
optionsWebSocketCloseOptions參考[WebSocketCloseOptions]。

返回值:

類型說明
Promise以Promise形式返回關閉連接的結果。

示例:

let ws = webSocket.createWebSocket();
let url = "ws://"
let promise = ws.close({
	code: 1000,
	reason: "your reason"
});
promise.then((value) = > {
	console.log("close success")
}).catch((err) = > {
	console.log("close fail, err is " + JSON.stringify(err))
});

on('open')

on(type: 'open', callback: AsyncCallback ): void

訂閱WebSocket的打開事件,使用callback方式作為異步方法。

系統(tǒng)能力 :SystemCapability.Communication.NetStack

參數(shù):

參數(shù)名類型必填說明
typestring'open':WebSocket的打開事件。
callbackAsyncCallback回調(diào)函數(shù)。

示例:

let ws = webSocket.createWebSocket();
ws.on('open', (err, value) = > {
	console.log("on open, status:" + value['status'] + ", message:" + value['message']);
});

off('open')

off(type: 'open', callback?: AsyncCallback ): void

取消訂閱WebSocket的打開事件,使用callback方式作為異步方法。

說明: 可以指定傳入on中的callback取消一個訂閱,也可以不指定callback清空所有訂閱。

系統(tǒng)能力 :SystemCapability.Communication.NetStack

參數(shù):

參數(shù)名類型必填說明
typestring'open':WebSocket的打開事件。
callbackAsyncCallback回調(diào)函數(shù)。

示例:

let ws = webSocket.createWebSocket();
let callback1 = (err, value) = > {
	console.log("on open, status:" + value['status'] + ", message:" + value['message']);
}
ws.on('open', callback1);
// 可以指定傳入on中的callback取消一個訂閱,也可以不指定callback清空所有訂閱
ws.off('open', callback1);

on('message')

on(type: 'message', callback: AsyncCallback): void

訂閱WebSocket的接收到服務器消息事件,使用callback方式作為異步方法。

說明: AsyncCallback中的數(shù)據(jù)可以是字符串(API 6)或ArrayBuffer(API 8)。

系統(tǒng)能力 :SystemCapability.Communication.NetStack

參數(shù):

參數(shù)名類型必填說明
typestring'message':WebSocket的接收到服務器消息事件。
callbackAsyncCallback回調(diào)函數(shù)。

示例:

let ws = webSocket.createWebSocket();
ws.on('message', (err, value) = > {
	console.log("on message, message:" + value);
});

off('message')

off(type: 'message', callback?: AsyncCallback): void

取消訂閱WebSocket的接收到服務器消息事件,使用callback方式作為異步方法。

說明: AsyncCallback中的數(shù)據(jù)可以是字符串(API 6)或ArrayBuffer(API 8)。 可以指定傳入on中的callback取消一個訂閱,也可以不指定callback清空所有訂閱。

系統(tǒng)能力 :SystemCapability.Communication.NetStack

參數(shù):

參數(shù)名類型必填說明
typestring'message':WebSocket的接收到服務器消息事件。
callbackAsyncCallback回調(diào)函數(shù)。

示例:

let ws = webSocket.createWebSocket();
ws.off('message');

on('close')

on(type: 'close', callback: AsyncCallback<{ code: number, reason: string }>): void

訂閱WebSocket的關閉事件,使用callback方式作為異步方法。

系統(tǒng)能力 :SystemCapability.Communication.NetStack

參數(shù):

參數(shù)名類型必填說明
typestring'close':WebSocket的關閉事件。
callbackAsyncCallback<{ code: number, reason: string }>回調(diào)函數(shù)。

示例:

let ws = webSocket.createWebSocket();
ws.on('close', (err, value) = > {
	console.log("on close, code is " + value.code + ", reason is " + value.reason);
});

off('close')

off(type: 'close', callback?: AsyncCallback<{ code: number, reason: string }>): void

取消訂閱WebSocket的關閉事件,使用callback方式作為異步方法。

說明: 可以指定傳入on中的callback取消一個訂閱,也可以不指定callback清空所有訂閱。

系統(tǒng)能力 :SystemCapability.Communication.NetStack

參數(shù):

參數(shù)名類型必填說明
typestring'close':WebSocket的關閉事件。
callbackAsyncCallback<{ code: number, reason: string }>回調(diào)函數(shù)。

示例:

let ws = webSocket.createWebSocket();
ws.off('close');

on('error')

on(type: 'error', callback: ErrorCallback): void

訂閱WebSocket的Error事件,使用callback方式作為異步方法。

系統(tǒng)能力 :SystemCapability.Communication.NetStack

參數(shù):

參數(shù)名類型必填說明
typestring'error':WebSocket的Error事件。
callbackErrorCallback回調(diào)函數(shù)。

示例:

let ws = webSocket.createWebSocket();
ws.on('error', (err) = > {
	console.log("on error, error:" + JSON.stringify(err))
});

off('error')

off(type: 'error', callback?: ErrorCallback): void

取消訂閱WebSocket的Error事件,使用callback方式作為異步方法。

說明: 可以指定傳入on中的callback取消一個訂閱,也可以不指定callback清空所有訂閱。

系統(tǒng)能力 :SystemCapability.Communication.NetStack

參數(shù):

參數(shù)名類型必填說明
typestring'error':WebSocket的Error事件。
callbackErrorCallback回調(diào)函數(shù)。

示例:

let ws = webSocket.createWebSocket();
ws.off('error');

WebSocketRequestOptions

建立WebSocket連接時,可選參數(shù)的類型和說明。

系統(tǒng)能力 :以下各項對應的系統(tǒng)能力均為SystemCapability.Communication.NetStack。

參數(shù)名類型必填說明
headerObject建立WebSocket連接可選參數(shù),代表建立連接時攜帶的HTTP頭信息。參數(shù)內(nèi)容自定義,也可以不指定。

WebSocketCloseOptions

關閉WebSocket連接時,可選參數(shù)的類型和說明。

系統(tǒng)能力 :以下各項對應的系統(tǒng)能力均為SystemCapability.Communication.NetStack。

參數(shù)名類型必填說明
codenumber錯誤碼,關閉WebSocket連接時的可選參數(shù),可根據(jù)實際情況來填。默認值為1000。
reasonstring原因值,關閉WebSocket連接時的可選參數(shù),可根據(jù)實際情況來填。默認值為空字符串("")。

close錯誤碼說明

發(fā)送給服務端的錯誤碼可以自行定義,下面的列表僅供參考。

系統(tǒng)能力 :以下各項對應的系統(tǒng)能力均為SystemCapability.Communication.NetStack。

說明
1000正常關閉
1001服務器主動關閉
1002協(xié)議錯誤
1003無法處理的數(shù)據(jù)類型
1004~1015保留值

審核編輯 黃宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 接口
    +關注

    關注

    33

    文章

    8612

    瀏覽量

    151275
  • 網(wǎng)絡管理

    關注

    0

    文章

    120

    瀏覽量

    27679
  • WebSocket
    +關注

    關注

    0

    文章

    29

    瀏覽量

    3752
  • 鴻蒙
    +關注

    關注

    57

    文章

    2361

    瀏覽量

    42878
收藏 人收藏

    評論

    相關推薦

    socket 和 WebSocket 的區(qū)別

    在現(xiàn)代網(wǎng)絡通信中,Socket和WebSocket是兩種常見的通信協(xié)議。它們在實現(xiàn)網(wǎng)絡通信、數(shù)據(jù)傳輸?shù)确矫姘l(fā)揮著重要作用。然而,它們之間存在一些關鍵的區(qū)別。 1. Socket(套接字) 1.1
    的頭像 發(fā)表于 11-12 14:33 ?462次閱讀

    socket與WebSocket的區(qū)別與聯(lián)系

    ) : Socket是一種通信端點,它在網(wǎng)絡編程中用于實現(xiàn)不同主機之間的通信。Socket可以是TCP套接字或UDP套接字,分別對應于TCP(傳輸控制協(xié)議)和UDP(用戶數(shù)據(jù)報協(xié)議)。 TCP套接字提供了可靠的、面向連接的通信服務,而UDP套接字則提供了不可靠的、無
    的頭像 發(fā)表于 11-04 09:19 ?437次閱讀

    不可錯過的Air780E之WebSocket應用示范!小白篇

    咋們今天說的Air780E之WebSocket應用示范針對小白絕對是不可以錯過的示例。
    的頭像 發(fā)表于 11-03 20:16 ?847次閱讀
    不可錯過的Air780E之<b class='flag-5'>WebSocket</b>應用示范!小白篇

    ESP8266_RTOS_SDK 1.4.0中的“websocket_demo”不起作用是怎么回事?

    新的SDK用戶在這里。我剛剛嘗試了昨天發(fā)布的 ESP8266_RTOS_SDK 1.4.0 中包含的示例“websocket_demo”。我唯一更改的是 websocket.c 中的 wifi 憑據(jù)
    發(fā)表于 07-18 07:05

    websocket.c RTOS演示中缺少對wifi_connect()的調(diào)用怎么辦?

    在 RTOS SDK 1.3 中,有一個名為 /examples/websocket_demo/websocket/websocket.c 的示例。在函數(shù)中有一個名為 websocket
    發(fā)表于 07-18 06:37

    請問websocket庫怎么讀取服務器發(fā)來的數(shù)據(jù)?

    官方websocket庫怎么讀取服務器發(fā)來的數(shù)據(jù)?
    發(fā)表于 06-25 06:40

    鴻蒙開發(fā)網(wǎng)絡管理ohos.net.socket之Socket連接

    綁定IP地址和端口,端口可以指定或由系統(tǒng)隨機分配。使用Promise方式作為異步方法。
    的頭像 發(fā)表于 06-19 09:26 ?419次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發(fā)網(wǎng)絡</b><b class='flag-5'>管理</b>:<b class='flag-5'>ohos.net</b>.socket之Socket<b class='flag-5'>連接</b>

    鴻蒙開發(fā)網(wǎng)絡管理ohos.net.connection之網(wǎng)絡連接管理

    以下各項對應的系統(tǒng)能力均為SystemCapability.Communication.NetManager.Core。
    的頭像 發(fā)表于 06-18 09:20 ?759次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發(fā)網(wǎng)絡</b><b class='flag-5'>管理</b>:<b class='flag-5'>ohos.net</b>.connection之<b class='flag-5'>網(wǎng)絡連接管理</b>

    ESP32進行websocket通信接收數(shù)據(jù)出錯的原因?

    開發(fā),支持一對一私聊和一對多公聊 W (104983) WEBSOCKET: Total payload length=277, data_len=277, current payload offset
    發(fā)表于 06-14 07:42

    鴻蒙原生應用開發(fā)-網(wǎng)絡管理模塊總述

    一、網(wǎng)絡管理模塊主要提供以下功能: HTTP數(shù)據(jù)請求:通過HTTP發(fā)起一個數(shù)據(jù)請求。 WebSocket連接:使用WebSocket建立服務
    發(fā)表于 04-08 09:45

    鴻蒙原生應用開發(fā)-網(wǎng)絡管理WebSocket連接

    。使用該功能需要申請ohos.permission.INTERNET權限。具體接口說明如下表。 三、開發(fā)步驟 1.導入需要的webSocket模塊。 2.創(chuàng)建一個WebSocket
    發(fā)表于 04-07 09:46

    鴻蒙原生應用開發(fā)-網(wǎng)絡管理Socket連接(二)

    。 import socket from \'@ohos.net.socket\'; // 創(chuàng)建一個TCPSocket連接,返回一個TCPSocket對象。 let tcp
    發(fā)表于 04-02 15:22

    鴻蒙OS開發(fā)實例:【窺探網(wǎng)絡請求】

    HarmonyOS 平臺中使用網(wǎng)絡請求,需要引入 "@ohos.net.http", 并且需要在 module.json5 文件中申請網(wǎng)絡權限, 即 “ohos.permission.
    的頭像 發(fā)表于 04-01 16:11 ?800次閱讀
    <b class='flag-5'>鴻蒙</b>OS<b class='flag-5'>開發(fā)</b>實例:【窺探<b class='flag-5'>網(wǎng)絡</b>請求】

    恒訊科技帶大家深入理解:WebSocket服務器的工作原理

    WebSocket是一種在單個TCP連接上進行全雙工通信的通信協(xié)議。它的設計目標是在Web瀏覽器和服務器之間提供低延遲、高效的雙向通信。下面是深入理解WebSocket服務器工作原理的一些關鍵概念
    的頭像 發(fā)表于 01-29 16:48 ?489次閱讀

    一文詳解WebSocket協(xié)議

    在效率和網(wǎng)絡帶寬利用率方面存在諸多問題。WebSocket協(xié)議應運而生,對外提供了簡單的雙向數(shù)據(jù)傳輸能力。
    的頭像 發(fā)表于 01-07 11:26 ?7486次閱讀
    一文詳解<b class='flag-5'>WebSocket</b>協(xié)議
    主站蜘蛛池模板: 天天综合天天色| 国产在线视频你懂得| 欧美1819| 天天上天天干| 国产日韩精品一区二区三区 | 成年色黄大色黄大片 视频| 色香首页| 久久观看| 夜色爽| 国产精品毛片一区二区三区| 日本免费福利视频| 亚洲国产成a人v在线观看| 亚洲视频在线一区二区| 婷婷色香五月激情综合2020| 免费在线观看大片影视大全| 亚洲精品蜜桃久久久久久| 国产国产人免费人成免费视频| se94se亚洲欧美在线| 国产日本在线观看| 夜夜嗷| 加勒比一到三区| 色之综合天天综合色天天棕色| 999毛片免费观看| 高清人妖shemale japan| 国产一级真人毛爱做毛片| 免费看吻胸亲嘴激烈网站| 色妞影视| 特级a毛片| 性色在线视频| 伊人精品久久久大香线蕉99| 久久99国产精品免费观看| 日韩亚洲人成在线综合| 亚洲视频一区二区| 亚洲一区二区在线播放| 亚洲人色大成年网站在线观看| 亚洲美女精品| 欧美三级色| 久久新地址| 久久国产高清视频| 国外免费一级| 日日日干干干|