Vue+Nodejs 使用WebSocket创建一个简易聊天室

文章目录

    • 一、页面效果
    • 二、架构流程
    • 三、技术细节
      • 1.客户端
      • 2. 服务端

一、页面效果

在这里插入图片描述

二、架构流程

使用vue编写前端页面,nodejs处理服务端消息,WebSocket进行实时通信

三、技术细节

1.客户端

<template><div><form onsubmit="return false"><textarea  id="responseTest"  style="width: 500px; height: 300px"  ></textarea><br /><input  type="text"  name="message"  style="width: 300px"  :value="inputVal"  @input="input"  /><input type="button" value="发送消息" @click="send(inputVal)" /><input type="button" value="清空聊天记录" @click="clean" /></form></div>
</template><script>
export default {data() {return {inputVal: '欢迎来到二二得四的聊天室',socket:null}},methods: {testWebsocket() {if (!window.WebSocket) {window.WebSocket = window.MozWebSocket}if (window.WebSocket) {this.socket = new WebSocket('ws://localhost:8088/ws')this.socket.onmessage = function (event) {var ta = document.getElementById('responseTest')ta.value = ta.value + '\n' + event.data}this.socket.onopen = function (event) {var ta = document.getElementById('responseTest')ta.value = '连接开启!'}this.socket.onclose = function (event) {var ta = document.getElementById('responseTest')ta.value = '连接关闭!'}} else {alert('你的浏览器不支持WebSocket')}},input(e) {this.inputVal = e.detail.value},clean() {document.getElementById('responseTest').value = ''},send(message) {if (!window.WebSocket) {return}if (this.socket.readyState === WebSocket.OPEN) {this.socket.send(message)} else {alert('连接没有开启')}},},mounted() {this.testWebsocket()},
}
</script><style></style>

2. 服务端

使用的是nodejs

const ws = require('ws')const webserve = new ws.Server({port:8088})//打开WebSocket服务器:通过监听open事件打开服务器
webserve.on('open',function open() {console.log('connected')
})//关闭WebSocket服务器:通过监听close事件关闭服务器
webserve.on('close',function close() {console.log('disconnected')
})//监听连接:ws通过connection事件来监听连接
webserve.on('connection',function connection(res,req) {const ip1 =  req.headers['x-forwarded-for'] || req.socket.remoteAddressconst port1 = req.socket.remotePortconst clientName = ip1+port1console.log('连接已开启,开始发送消息')// 发送数据:ws通过send()方法来发送到客户端数据// res.send('welcome,'+clientName)//接收数据:ws通过message事件来接收数据。当客户端有消息发送给服务器时,服务器就能够触发该消息res.on('message',function incoming(message) {console.log('received: %s from %s',message,clientName)/*** 准备的状态:ws中WebSocket类具有以下4中准备状态* 1、CONNCETION:值为0,表示连接还没有打开* 2、OPEN:值为1,表示连接已经打开,可以通信了* 3、CLOSING:值为2,表示连接正在关闭* 4、CLOSED:值为2,表示连接已经关闭*/webserve.clients.forEach(function each(client) {if(client.readyState === ws.OPEN){client.send(message.toString())}})})
})

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/8696.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【itext7】itext7操作PDF文档之添加表单控件(单行文本框、多行文本框、单选框、复选框、下拉框、按钮)

这篇文章&#xff0c;主要介绍itext7操作PDF文档之添加表单控件&#xff08;单行文本框、多行文本框、单选框、复选框、下拉框、按钮&#xff09;。 目录 一、itext操作PDF表单 1.1、添加单行文本框 1.2、添加多行文本框 1.3、添加单选框 1.4、添加复选框 1.5、添加下拉框…

无涯教程-html()

html()方法获取第一个匹配元素的html内容。此属性在XML文档上不可用&#xff0c;但适用于XHTML文档。 html( ) - 语法 selector.html() html( ) - 示例 以下示例将获取第一段的HTML内容&#xff0c;并将其显示在第二段中。请同时检查 html(val)方法的描述。 <html>&…

WEB安全测试通常要考虑的测试点

1、问题&#xff1a;没有被验证的输入 测试方法&#xff1a; 数据类型&#xff08;字符串&#xff0c;整型&#xff0c;实数&#xff0c;等&#xff09; 允许的字符集 最小和最大的长度 是否允许空输入 参数是否是必须的 重复是否允许 数值范围 特定的值&#xff08;枚举型&a…

MacBook安装Git三种方式

MacBook安装Git三种方式 git官方下载地址: https://git-scm.com/download 方式一(推荐) Git官网下载最新git Mac版本安装 下载地址: https://git-scm.com/download/mac Binary installer 二进制安装 下载 git-2.27.0-intel-universal-mavericks.dmg 点击安装 查看版本 git …

大语言模型

LLM通常基于Transformer架构构建&#xff0c;这类模型依赖于自注意力机制。Transformer能够高效利用计算资源&#xff0c;使得训练更大规模的语言模型成为可能。 例如&#xff0c;GPT-4包含数十亿个参数&#xff0c;在大规模数据集上训练&#xff0c;在其权重中有效编码了大量…

k8s使用helm部署Harbor镜像仓库并启用SSL

1、部署nfs存储工具 参照&#xff1a;https://zhaoll.blog.csdn.net/article/details/128155767 2、部署helm 有多种安装方式&#xff0c;根据自己的k8s版本选择合适的helm版本 参考&#xff1a;https://blog.csdn.net/qq_30614345/article/details/131669319 3、部署Harbo…

WPF实战学习笔记04-菜单导航

菜单导航 添加文件与文件夹 添加文件夹 ​ ./Extensions 添加文件&#xff3b;类型&#xff1a;用户控件&#xff3d; ./Views/IndexView.xaml ./Views/MemoView.xaml ./Views/TodoView.xaml ./Views/SettingsView.xaml ./ViewModels/IndexViewModel.cs ./ViewModels/IndexV…

0成本搭建自己的云数据库

第一步&#xff0c;租免费的云服务器 www.aliyun.com 阿里云的&#xff0c;可以免费租三个月 进入主页后选择云服务器ESC 选择这款&#xff0c;点击试用就行 第二步&#xff0c;配置服务器 在配置服务器系统的时候选择centos&#xff0c;省事&#xff0c;别选ubuntu&#x…

动手学深度学习——线性回归从零开始

生成数据集synthetic_data()读取数据集data_iter()初始化模型参数w, b定义模型&#xff1a;线性回归模型linreg()定义损失函数&#xff1a;均方损失squared_loss()定义优化算法&#xff1a;梯度下降sgd()进行训练&#xff1a;输出损失loss和估计误差 %matplotlib inline impor…

java项目之人才公寓管理系统(ssm+mysql+jsp)

风定落花生&#xff0c;歌声逐流水&#xff0c;大家好我是风歌&#xff0c;混迹在java圈的辛苦码农。今天要和大家聊的是一款基于ssm的人才公寓管理系统。技术交流和部署相关看文章末尾&#xff01; 开发环境&#xff1a; 后端&#xff1a; 开发语言&#xff1a;Java 框架&…

iOS pod EaseIMKit库如何放在本地使用

在使用环信EaseIMKit库的时候&#xff0c;发现有些开发者需要改动库中的一些逻辑&#xff0c;或者有UI上的一些调整&#xff0c;如果直接去改pods里面的库&#xff0c;在之后的库版本升级会把之前修改过的代码覆盖掉&#xff0c;这个时候我们就需要pod指向本地的库&#xff0c;…

KubeVela篇05:为kubevela开发terraform-mycloud Addon插件

通过前面的章节,我们已经学习了解terraform,并通过vpc资源例子,为私有云/混合云开发了terraform provider,这一节介绍如何将我们开发的mycloud terraform provider整合到kubevela控制平台上,以通过在application中声明一个kubevela组件的方式去申请基础设施资源。 我们需…

【数据结构】---时间复杂度与空间复杂度

时间复杂度与空间复杂度 1.&#x1f4c9; 时间复杂度&#x1f4cc;1.1 时间复杂度的概念1.2 大O的渐进表示法 &#x1f3f0;空间复杂度&#x1f4c3;例题分析1.案例&#xff08;常数阶&#xff09;2.案例&#xff08;线性阶&#xff09;3.案例&#xff1a;&#xff08;平方阶&a…

css元素定位:通过元素的标签或者元素的id、class属性定位

前言 大部分人在使用selenium定位元素时&#xff0c;用的是xpath元素定位方式&#xff0c;因为xpath元素定位方式基本能解决定位的需求。xpath元素定位方式更直观&#xff0c;更好理解一些。 css元素定位方式往往被忽略掉了&#xff0c;其实css元素定位方式也有它的价值&…

【数据库 - 用户权限管理】(简略)

目录 一、概述 二、用户权限类型 1.ALL PRIVILEGES 2.CREATE 3.DROP 4.SELECT 5.INSERT 6.UPDATE 7.DELETE 8.INDEX 9.ALTER 10.CREATE VIEW和CREATE ROUTINE 11.SHUTDOWN 12GRANT OPTION 三、语句格式 1.用户赋权 2.权限删除 3.用户删除 一、概述 数据库用…

Redis多级缓存

文章目录 多级缓存背景JVM进程缓存Caffeine案例分析安装MySQL导入SQL Lua语法变量与循环数据类型声明变量循环 函数与条件控制函数条件控制 实现多级缓存安装OpenResty安装opm工具目录结构配置Nginx的环境变量运行启动 快速入门反向代理流程OpenResty监听请求编写item.lua 请求…

基于深度学习的高精度交通信号灯检测系统(PyTorch+Pyside6+YOLOv5模型)

摘要&#xff1a;基于深度学习的高精度交通信号灯检测识别可用于日常生活中检测与定位交通信号灯目标&#xff0c;利用深度学习算法可实现图片、视频、摄像头等方式的交通信号灯目标检测识别&#xff0c;另外支持结果可视化与图片或视频检测结果的导出。本系统采用YOLOv5目标检…

AI > 语音识别开源项目列举

名称所属开发机构使用场景优缺点技术特点占有率描述CMU Sphinx卡内基梅隆大学嵌入式设备、服务器应用优点&#xff1a;可用于嵌入式设备和服务器应用。 缺点&#xff1a;准确率相对较低&#xff0c;适用范围有限。- 支持多种语言模型和工具。- 适用于嵌入式设备和服务器应用。中…

站在读者角度:10个技巧写出有价值的文章

站在读者的角度&#xff0c;以下是10个写出有价值的文章的技巧&#xff1a; 1.确定你的目标读者&#xff1a;在开始写作之前&#xff0c;确定你的目标读者是谁&#xff0c;这有助于你更好地针对他们的需求和兴趣来写作。 2.了解你的读者&#xff1a;通过调查、研究和互动&…

Unity UGUI的EventSystem(事件系统)组件的介绍及使用

Unity UGUI的EventSystem&#xff08;事件系统&#xff09;组件的介绍及使用 1. 什么是EventSystem组件&#xff1f; EventSystem是Unity UGUI中的一个重要组件&#xff0c;用于处理用户输入事件&#xff0c;如点击、拖拽、滚动等。它负责将用户输入事件传递给合适的UI元素&a…