HarmonyOS 鸿蒙Next 原生应用开发-网络管理WebSocket连接

发布于 1周前 作者 bupafengyu 最后一次编辑是 5天前 来自 鸿蒙OS

HarmonyOS 鸿蒙Next 原生应用开发-网络管理WebSocket连接

一、场景介绍

使用WebSocket建立服务器与客户端的双向连接,需要先通过createWebSocket()方法创建WebSocket对象,然后通过connect()方法连接到服务器。当连接成功后,客户端会收到open事件的回调,之后客户端就可以通过send()方法与服务器进行通信。当服务器发信息给客户端时,客户端会收到message事件的回调。当客户端不要此连接时,可以通过调用close()方法主动断开连接,之后客户端会收到close事件的回调。

若在上述任一过程中发生错误,客户端会收到error事件的回调。

二、接口说明

WebSocket连接功能主要由webSocket模块提供。使用该功能需要申请ohos.permission.INTERNET权限。具体接口说明如下表。

接口名

功能描述

createWebSocket()

创建一个WebSocket连接。

connect()

根据URL地址,建立一个WebSocket连接。

send()

通过WebSocket连接发送数据。

close()

关闭WebSocket连接。

on(type: ‘open’)

订阅WebSocket的打开事件。

off(type: ‘open’)

取消订阅WebSocket的打开事件。

on(type: ‘message’)

订阅WebSocket的接收到服务器消息事件。

off(type: ‘message’)

取消订阅WebSocket的接收到服务器消息事件。

on(type: ‘close’)

订阅WebSocket的关闭事件。

off(type: ‘close’)

取消订阅WebSocket的关闭事件

on(type: ‘error’)

订阅WebSocket的Error事件。

off(type: ‘error’)

取消订阅WebSocket的Error事件。

三、开发步骤

1.导入需要的webSocket模块。

2.创建一个WebSocket连接,返回一个WebSocket对象。

3.(可选)订阅WebSocket的打开、消息接收、关闭、Error事件。

4.根据URL地址,发起WebSocket连接。

5.使用完WebSocket连接之后,主动断开连接。

import webSocket from ‘@ohos.net.webSocket’;

var defaultIpAddress = “ws://”; let ws = webSocket.createWebSocket(); ws.on(‘open’, (err, value) => { console.log(“on open, status:” + JSON.stringify(value)); // 当收到on(‘open’)事件时,可以通过send()方法与服务器进行通信 ws.send(“Hello, server!”, (err, value) => { if (!err) { console.log(“Message sent successfully”); } else { console.log(“Failed to send the message. Err:” + JSON.stringify(err)); } }); }); ws.on(‘message’, (err, value) => { console.log(“on message, message:” + value); // 当收到服务器的bye消息时(此消息字段仅为示意,具体字段需要与服务器协商),主动断开连接 if (value === ‘bye’) { ws.close((err, value) => { if (!err) { console.log(“Connection closed successfully”); } else { console.log("Failed to close the connection. Err: " + 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(“Connected successfully”); } else { console.log(“Connection failed. Err:” + JSON.stringify(err)); } });

本文参考引用HarmonyOS官方开发文档,基于API9。


更多关于HarmonyOS 鸿蒙Next 原生应用开发-网络管理WebSocket连接的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html

5 回复
学习学习

更多关于HarmonyOS 鸿蒙Next 原生应用开发-网络管理WebSocket连接的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


onPageShow() {
if (this.isConnect && this.isOpen) {
this.ws.on("message", (err,value) => {
Prompt.showToast({message: JSON.stringify(value)});
if (!err) {
this.messageData.push(value)
}
})
this.ws.on('close', (err, value) => {
console.log("PYC: on close, code is " + value.code + ", reason is " + value.reason);
});
this.ws.on('error', (err) => {
console.log("PYC: on error, error:" + JSON.stringify(err));
});
}
}

一直没有触发到,怎么破解??

在反复检查核对一下代码呗。

和楼主问题一样,断开socket服务器链接,客户端的error不会触发。

针对您提到的HarmonyOS鸿蒙Next原生应用开发中的网络管理WebSocket连接问题,这里提供一些基本要点和技术背景信息,帮助您理解和处理相关开发任务。

在HarmonyOS原生应用开发中,WebSocket连接通常用于实现客户端与服务器之间的全双工通信。要管理WebSocket连接,您需要:

  1. 创建WebSocket实例:使用系统提供的API或第三方库来实例化WebSocket客户端。
  2. 建立连接:指定服务器的URL和端口,通过调用相应的方法尝试建立连接。
  3. 处理事件:实现事件监听器,以处理连接打开、消息接收、错误和连接关闭等事件。
  4. 发送和接收数据:使用WebSocket实例的方法发送数据,并在事件监听器中处理接收到的数据。
  5. 关闭连接:在适当的时候调用关闭连接的方法,释放资源。

确保您的应用具有适当的网络权限,并在开发过程中注意处理异常和错误,以提高应用的健壮性和用户体验。

如果您遇到具体的代码问题或错误消息,请检查API文档和示例代码,确保您的实现符合HarmonyOS的开发规范。如果问题依旧没法解决请联系官网客服,官网地址是:https://www.itying.com/category-93-b0.html。

回到顶部