鸿蒙 HarmonyOS--WebSocket连接

WebSocket是一种长连接的双向通信方式,一旦连接完成,双方就能相互主动发起通信,每次通信不需要再次连接。

客户端向服务器发送握手报文,服务器响应确认握手的报文,连接就建立了,连接完成后,双方都可以主动发送数据,直到有一方发来断开连接的信号来关闭连接。

下面使用了一个WebSocket在线测试的url,客户端发送了什么消息,服务端就会返回什么消息,用id来区分客户端和服务端。

typescript 复制代码
import { webSocket } from '@kit.NetworkKit'
import { promptAction } from '@kit.ArkUI'
import { BusinessError } from '@kit.BasicServicesKit'

interface messageInfo {
  //用户id,我这里的设置:客户端的id为1001,服务端id为1002
  id: string
  msg: string
}

@Entry
@Component
struct WebSocketPage {
  @State data: messageInfo[] = [] //消息数组
  @State myMsg: string = ''
  //这是websocket在线测试url,客户端发送什么,服务器就会返回什么
  @State url: string = 'ws://124.222.224.186:8800/websocket'
  ws: webSocket.WebSocket | null = null

  async aboutToAppear() {
    this.connect2Server(this.url)
    this.receiveMsg()
  }

  //连接服务端
  connect2Server(defaultIpAddress: string) {
    this.ws = webSocket.createWebSocket();
    //根据URL地址,建立一个WebSocket连接
    this.ws.connect(defaultIpAddress, (err: BusinessError, value: boolean) => {
      if (!err) {
        //连接成功
        promptAction.showToast({ message: 'connect success ' })
      } else {
        AlertDialog.show({ message: 'connect fail ' + err.message })
      }
    })

    this.ws.on('open', (err: BusinessError, value: object) => {
      //打开webSocket失败
      if (err) {
        AlertDialog.show({ message: JSON.stringify(err) })
      }
    })
  }

  //接收到服务器消息
  receiveMsg() {
    if (this.ws) {
      this.ws.on('message', (err, value) => {
        this.data.push({ id: '1002', msg: JSON.stringify(value) })
      })
    }
  }

  //发送消息到服务端
  sendMsg2Server(msg: string) {
    if (this.ws) {
      this.ws.send(msg)
        .catch((e: Error) => {
          AlertDialog.show({ message: '发送失败' + e.message })
        })
    }
  }

  build() {
    Navigation() {
      Column() {
        List() {
          ForEach(this.data, (Item: messageInfo) => {
            ListItem() {
              Row() {
                //网络图片需要打开网络权限
                Image(Item.id === '1001' ?
                  "https://tse3-mm.cn.bing.net/th/id/OIP-C.JRIYJ3EqtcLF1LwK3oxjgAHaGg?w=201&h=181&c=7&r=0&o=5&dpr=1.3&pid=1.7" :
                  "https://tse3-mm.cn.bing.net/th/id/OIP-C.7Z068v6GRuOJVYYUSHsBDgHaNK?w=115&h=182&c=7&r=0&o=5&dpr=1.3&pid=1.7")
                  .height(40)
                  .width(40)
                  .borderRadius(6)
                Row() {
                  Text(Item.msg)
                    .backgroundColor(Item.id === '1001' ? Color.Orange : Color.Yellow)
                    .padding(10)
                    .lineHeight(24)
                    .margin({
                      left: 10,
                      right: 10
                    })
                    .borderRadius(5)
                }
                .layoutWeight(6)
                .justifyContent(Item.id === '1001' ? FlexAlign.End : FlexAlign.Start)

                Text().layoutWeight(1)
              }
              .alignItems(VerticalAlign.Top)
              .direction(Item.id === '1001' ? Direction.Rtl : Direction.Ltr)
            }
            .margin({ bottom: 10 })
          })
        }
        .padding(10)
        .backgroundColor(Color.Pink)
        .layoutWeight(1)

        TextInput({ placeholder: '请输入', text: $$this.myMsg })
          .onSubmit(() => {
            this.sendMsg2Server(this.myMsg)
            this.data.push({ id: '1001', msg: this.myMsg } as messageInfo)
            //清空输入框内容
            this.myMsg = ''
          })
      }
      .height('100%')
      .width('100%')
    }
    .title('webSocket通信')
    .titleMode(NavigationTitleMode.Mini)
  }
}
相关推荐
别说我什么都不会8 小时前
ohos.net.http请求HttpResponse header中set-ccokie值被转成array类型
网络协议·harmonyos
码是生活8 小时前
鸿蒙开发排坑:解决 resourceManager.getRawFileContent() 获取文件内容为空问题
前端·harmonyos
鸿蒙场景化示例代码技术工程师9 小时前
基于Canvas实现选座功能鸿蒙示例代码
华为·harmonyos
小脑斧爱吃鱼鱼10 小时前
鸿蒙项目笔记(1)
笔记·学习·harmonyos
鸿蒙布道师10 小时前
鸿蒙NEXT开发对象工具类(TS)
android·ios·华为·harmonyos·arkts·鸿蒙系统·huawei
zhang10620910 小时前
HarmonyOS 基础组件和基础布局的介绍
harmonyos·基础组件·基础布局
马剑威(威哥爱编程)11 小时前
在HarmonyOS NEXT 开发中,如何指定一个号码,拉起系统拨号页面
华为·harmonyos·arkts
GeniuswongAir12 小时前
Flutter极速接入IM聊天功能并支持鸿蒙
flutter·华为·harmonyos
90后的晨仔15 小时前
鸿蒙ArkUI框架中的状态管理
harmonyos
别说我什么都不会1 天前
OpenHarmony 5.0(API 12)关系型数据库relationalStore 新增本地数据变化监听接口介绍
api·harmonyos