热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【FFH】实时聊天室之WebSocket实战

【FFH】实时聊天室之WebSocket实战前言WebSocket是什么?Demo展示代码实现①申请网络权限②导入webSocket模块③创建webSocket对象④

【FFH】实时聊天室之WebSocket实战

  • 前言
    • WebSocket是什么?
    • Demo展示
  • 代码实现
    • ① 申请网络权限
    • ② 导入webSocket模块
    • ③ 创建webSocket对象
    • ④ 连接webSocket通道
    • ⑤ 订阅通道内消息更新
    • ⑥ 发送消息
    • ⑦ 隐藏标题栏
    • ⑧ 样式设计


前言

如果要实现像微信聊天一样的功能,在组网内进行通信显然是不够的,所以软总线并不作用与这种远距离传输。如果我们要完成微信的聊天功能,传统的方法就是利用webSocket借助服务器进行全双工通信。

WebSocket是什么?

WebSocket 是 一种在单个 TCP 连接上进行全双工通讯的网络通信协议。

在以前没有webSocket的时候,大家都用HTTP协议进行网络通信,但是HTTP协议是一个无状态,无连接,单向的应用层协议,因此只能让客户端对服务端进行单向请求,服务端无法主动向客户端发送消息,导致了像实时聊天这种业务开展起来比较困难。

有开发者就使用HTTP进行长轮询的方案,也就是说需要HTTP在一段时间内必须一直保持连接请求,以获取最新的服务器的消息。这样显然效率低下,而且非常浪费资源。

因此就诞生了WebSocket,只需要进行一次连接,就可以一直保持全双工的通信状态。

Demo展示

下面我们就来用官方提供的WebSocket接口实现一个简易实时聊天室的Demo。效果如下:
ws.gif

代码实现

可以看到官方文档的接口说明,我们只需要简单用到几个接口就可以实现我们的业务需求了。

https://developer.harmonyos.com/cn/docs/documentation/doc-guides/websocket-connection-0000001333321005

image.png

① 申请网络权限

在config.json文件里面注册网络权限,该权限允许程序打开网络套接字,进行网络连接。

"reqPermissions": [{"name": "ohos.permission.INTERNET"}
]

② 导入webSocket模块

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

③ 创建webSocket对象

接着我们调用createWebSocket()接口生成一个webSocket对象,并且保存起来。

let ws = webSocket.createWebSocket();

④ 连接webSocket通道

调用connect()接口进行连接。这里需要一个URL作为参数传入,在这个demo中,直接用了一个以前开发好的服务器接口进行调用,但是不对外开放,因此大家只需要将自己开发好的接口地址放到”wsURL“内即可。

onInit() {let that = this;ws.connect("wsURL", (err, value) => {if (!err) {console.log("xxx---connect success");} else {console.log("xxx---connect fail, err:" + JSON.stringify(err));}});},

⑤ 订阅通道内消息更新

这里我们调用on( type:‘message’ )接口进行消息监听,这里要注意的是服务端传递过来的是字符串类型,所以如果消息是JSON对象,则需要用JSON.parse()进行解析,还原成JSON对象。

onInit() {let that = this;ws.on('message', (err, value) => {console.log("xxx---on message, message:" + value);//传递的是序列化后的字符串,需要解序列化为JSON对象let dataObj = JSON.parse(value)console.log("xxx---parse success---postId: "+dataObj.postId+",message:"+dataObj.message)that.message.push(dataObj)console.log("xxx---check message: "+JSON.stringify(that.message))});},

⑥ 发送消息

紧接着调用send()接口进行消息的发送,这里注意,如果要传递的是JSON对象,要使用JSON.stringify()进行序列化操作, 保证我们传递的是流字符串的形式。

在该接口的回调中,我们也可以打印出来,看看消息是否发送成功。

sendMessage(){let that = this;let data = {postId:that.id,message:that.sendMes}let dataStr = JSON.stringify(data)ws.send(dataStr, (err, value) => {if (!err) {console.log("xxx---send success");} else {console.log("xxx---send fail, err:" + JSON.stringify(err));}});that.message.push(data)},

⑦ 隐藏标题栏

细心的小伙伴就会发现,我的demo展示的黑色标题栏不见了,其实是可以隐藏掉的,只需要在config.json文件中module.abilities下添加几行代码即可。

"metaData":{"customizeData":[{"name": "hwc-theme","value": "androidhwext:style/Theme.Emui.NoTitleBar","extra":""}]}

⑧ 样式设计

接着就是简单设计一下界面样式,把获取到的消息渲染出来就完成啦。

<div class&#61;"container"><div style&#61;"width: 100%;height: 8%;color: #ff86868a;font-size: 25px;justify-content: center;position: absolute;"><text style&#61;"top: 10px;">实时聊天室text>div><list style&#61;"height: 80%;"><list-item for&#61;"{{message}}" class&#61;"{{$item.postId&#61;&#61;id?&#39;listItemRight&#39;:&#39;listItemLeft&#39;}}" ><div class&#61;"listItemDiv" ><text style&#61;"padding:5px;border-radius: 10px;font-size: 20px;margin: 5px;max-width: 70%;">{{$item.message}}text>div>list-item>list><div style&#61;"position: absolute;left:10px;bottom: 20px;"><textarea id&#61;"textarea" class&#61;"textarea" extend&#61;"true"placeholder&#61;"请输入聊天信息"onchange&#61;"inputChange" >textarea><button style&#61;"width: 75px;height: 50px;margin-left: 10px;background-color: #ff4848f5;" onclick&#61;"sendMessage"> 发送 button>div>div>

.container {display: flex;flex-direction: column;justify-content: center;align-items: center;left: 0px;top: 0px;width: 100%;height: 100%;
}
.textarea {placeholder-color: gray;width: 70%;
}.listItemDiv{background-color: #ff87f3d0;border-radius: 10px;}.listItemLeft{margin: 10px;width: 100%;justify-content: flex-start;
}
.listItemRight{margin: 10px;width: 100%;justify-content: flex-end;
}


推荐阅读
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • Linux服务器密码过期策略、登录次数限制、私钥登录等配置方法
    本文介绍了在Linux服务器上进行密码过期策略、登录次数限制、私钥登录等配置的方法。通过修改配置文件中的参数,可以设置密码的有效期、最小间隔时间、最小长度,并在密码过期前进行提示。同时还介绍了如何进行公钥登录和修改默认账户用户名的操作。详细步骤和注意事项可参考本文内容。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • Nginx使用AWStats日志分析的步骤及注意事项
    本文介绍了在Centos7操作系统上使用Nginx和AWStats进行日志分析的步骤和注意事项。通过AWStats可以统计网站的访问量、IP地址、操作系统、浏览器等信息,并提供精确到每月、每日、每小时的数据。在部署AWStats之前需要确认服务器上已经安装了Perl环境,并进行DNS解析。 ... [详细]
  • 本文介绍了在Python3中如何使用选择文件对话框的格式打开和保存图片的方法。通过使用tkinter库中的filedialog模块的asksaveasfilename和askopenfilename函数,可以方便地选择要打开或保存的图片文件,并进行相关操作。具体的代码示例和操作步骤也被提供。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • 本文介绍了PhysioNet网站提供的生理信号处理工具箱WFDB Toolbox for Matlab的安装和使用方法。通过下载并添加到Matlab路径中或直接在Matlab中输入相关内容,即可完成安装。该工具箱提供了一系列函数,可以方便地处理生理信号数据。详细的安装和使用方法可以参考本文内容。 ... [详细]
  • Google Play推出全新的应用内评价API,帮助开发者获取更多优质用户反馈。用户每天在Google Play上发表数百万条评论,这有助于开发者了解用户喜好和改进需求。开发者可以选择在适当的时间请求用户撰写评论,以获得全面而有用的反馈。全新应用内评价功能让用户无需返回应用详情页面即可发表评论,提升用户体验。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 本文详细介绍了在ASP.NET中获取插入记录的ID的几种方法,包括使用SCOPE_IDENTITY()和IDENT_CURRENT()函数,以及通过ExecuteReader方法执行SQL语句获取ID的步骤。同时,还提供了使用这些方法的示例代码和注意事项。对于需要获取表中最后一个插入操作所产生的ID或马上使用刚插入的新记录ID的开发者来说,本文提供了一些有用的技巧和建议。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
author-avatar
吉翠芙_899
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有