Vue + Nodejs + socket.io 实现聊天

Vue  代码

// 安装  socket.io-clientnpm i socket.io-clientimport io from 'socket.io-client';mounted () {// * location.origin 表示你的 socket 服务地址// * /XXXX/socket.io 表示 你的 socket 在服务器配置的 访问地址let socket = io(location.origin, {path: "/XXXX/socket.io"});this.soccket = socket;// 将 socket 挂载到全局this.$store.commit('setSocketMain', socket);// * 監聽 socket 鏈接成功socket.on('connect', () => {// userInfo 表示用户信息socket.emit('user:login', userInfo); // 发送一个自定义事件,如'user:login',以及用户信息  });// * 监听收到消息socket.on('message', message => {console.log('接收到信息', message);let  text = `${message.name}:${message.text}`;this.$notify({title: '消息提醒',dangerouslyUseHTMLString: true,message:text,type: "success",duration: 2000});// * 将消息显示在页面上this.pushMessage(message.text};})},methed:{// * 发送消息, 包含了 text,uid,toUid,fId,namepushMessage(arg){this.soccket.emit('message',arg)}}

NodeJS 代码

// * 先安装 socket.ionpm i socket.io// * 修改启动文件, 比如我的是 www.js
const express = require('express');
const http = require('http'); // 引入 http 模块
const socketIo = require('socket.io'); // 引入 socket.io 模块
// 实例化一个 express的对象
const app = express();
// 创建一个 HTTP 服务器实例
const server = http.createServer(app);
// 实例化 Socket.IO 并将其附加到 HTTP 服务器实例
const io = socketIo(server, {path: '/XXXX/socket.io', // 假设你的命名空间是 '/XXXX' , 这里也对应了 vue 那里的值
});//监听3000端口
server.listen(3000, function () {var host = server.address().address;var port = server.address().port;if (host == '::') {host = 'localhost:';}console.log(`启动成功访问地址 http://${host}${port}`);
});//暴露
module.exports = { app, io };// * 其中,  app 会 被 app.js 所引用, 作为启动// * io 可以在需要socket 的地方引用, 如 message.jsconst { io } = require('../../bin/www');// * socket 方法
const _socket = {// * socket - user 對象sockets: [],// * 用戶登錄login(socket, user) {this.sockets.push({uId: user.id,socketId: socket.id,socket: socket,});},// * 登出logout(socketId) {console.log('用戶離線');let u = this.sockets.filter((item) => item.socketId == socketId);if (u.length > 0) this.sockets.splice(this.sockets.indexOf(u[0]), 1);},// * 獲取當前用戶 的 socketgetSocket(e) {console.log('獲取當前用戶:', e);let u = this.sockets.filter((item) => item.socketId == e || item.uId == e);if (u.length > 0) return u[0];return {};},// * 發送消息pushMessage(e, message) {let user = this.getSocket(e);let socket = user.socket;if (socket) {socket.emit('message', message);} else {console.log(`用戶離線或用戶不存在`);}},
};// * 设置 Socket.IO 事件监听器
io.on('connection', (socket) => {let socketId = socket.id;// * 監聽用戶登錄socket.on('user:login', (user) => {console.log('有用戶上線了', user);_socket.login(socket, user);});// * 登出socket.on('user:logout', () => {socket.leave(socketId);_socket.logout(socketId);});// * 当客户端断开连接时socket.on('disconnect', () => {socket.leave(socketId);_socket.logout(socketId);});// * 监听接收消息socket.on('message',(arg)=>{const { fId,uid,name,toUid,text } = arg;// * 发送给指定人_socket.pushMessage(toUid, {fId: fId,uid: uid,toUid: toUid,name: decodeURI(name),text: text,});})
});

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

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

相关文章

抓包工具实战

Npcap下载: https://npcap.com/#download 安装抓包数据: WinPcap Download python抓包: from scapy.all import * if __name__ __main__:filterstr "tcp || udp"pr sniff(filterfilterstr, count4)

原生APP开发和Flutter开发的比较

原生APP开发和Flutter开发各有优缺点,适用于不同的场景和需求。下面是两者的详细比较,从开发语言、性能、开发效率、维护和更新、社区和支持等多个方面进行分析。北京木奇移动技术有限公司,专业的软件外包开发公司,欢迎交流合作。…

htb_BoardLight

信息收集 nmap -sSVC 10.10.11.11开放80端口,将boardlight.htb写入/etc/hosts 同步进行子域名和目录扫描 子域名扫不到 这个目录扫描很奇怪哈,明明访问80端口有页面,就是扫不出来 直接浏览器访问80端口,四处看看,发…

7、架构-架构的安全性

即使只限定在“软件架构设计”这个语境下,系统安全仍然是一 个很大的话题。我们谈论的计算机系统安全,不仅仅是指“防御系统 被黑客攻击”这样狭隘的安全,还至少应包括(不限于)以下这些问 题的具体解决方案。 认证&am…

如何实现Java中的单例模式?举例说明。

Java中的单例模式(Singleton Pattern)是一种创建型设计模式,确保一个类只有一个实例,并提供全局访问点。实现单例模式有多种方法,下面介绍几种常见的实现方式。 饿汉式单例(Eager Initialization&#xff…

自定义数据集训练 Yolo V10

上次介绍了Yolo 推理,本文我们将使用自己的数据集训练 Yolo V10,训练过程简单: 首先准备数据集,包括图片、标注训练推理 数据集准备 本次采用的数据集为内部数据,标注方法为 VOC 格式,首先我们需要建 VO…

智能辅导班技术架构:运用人工智能提升教育领域的学习效果

在教育领域,随着人工智能的发展,智能辅导班逐渐成为一种趋势。它利用先进的技术和创新的教学方法,为学生提供个性化的学习体验和全方位的辅导服务。本文将介绍智能辅导班的技术架构,探讨如何运用人工智能来提升学习效果。 ### 1. …

力扣之链表专题

1. (LeetCode-21)合并两个有序链表 将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 示例 1: 输入:l1 [1,2,4], l2 [1,3,4] 输出:[1,1,2,3,4,4]示例 2: 输入:l1 …

微服务架构-微服务实施

目录 一、概述 二、微服务拆分 2.1 概述 2.2 拆分原则 2.3 拆分方法 2.3.1 以数据为维度进行拆分 2.3.2 按照使用场景拆分 2.3.3 重要和非重要的拆分 2.3.4 变和不变的拆分 三、微服务通信 3.1 概述 3.2 微服务通信方式选择 3.3 微服务编排 3.4 API接口设计 3.5 …

「计网」网络初识

🎇个人主页:Ice_Sugar_7 🎇所属专栏:计网 🎇欢迎点赞收藏加关注哦! 网络初识 🍉IP 地址 & 端口号🍉网络协议🍌TCP/IP 网络协议 🍉封装和分用&#x1f349…

乡村振兴与乡村旅游创新:创新乡村旅游产品,提升旅游服务水平,打造特色乡村旅游品牌,助力美丽乡村建设

目录 一、引言 二、乡村旅游产品的创新 (一)挖掘乡村特色资源 (二)注重产品体验性 (三)创新旅游产品形态 三、旅游服务水平的提升 (一)加强基础设施建设 (二&…

如何上传模型素材创建3D漫游作品?

一、进入3D空间漫游互动工具编辑器 进入720云官网-点击“开始创作”-选择3D空间漫游-进入到作品创建页面。 二、上传模型及素材,创建生成3D空间漫游模型 1.创建3D空间作品:您可以选择新建空白作品或使用720云提供的预设空间模板,本篇主要介绍…

[手游] Florence逝去的爱弗洛伦斯

图片处理工具箱Hummingbird : Hummingbird使用智能压缩技术来减少文件的大小,支持:jpg、png、webp、svg、gif、gif、css、js、html、mp4、mov,可以设置压缩的同时等比例缩放图片或视频的尺寸。可以拖放文件夹压缩,一次最多可处理1…

redis(16):Redis的BigKey问题以及解决方案

1 什么是BigKey问题 在Redis中,每个Key都会对应一个Value,而这个Value的大小会影响Redis的性能表现。当我们存储的Value特别大时,就会出现BigKey问题。比如,在我们的互联网系统中,需要保存用户最新1万个粉丝的业务,或者一个用户的个人信息缓存,里面包括了基本资料、关系…

docker运行python项目

python项目结构 pythondocker/ │ ├── README.md # 项目说明文件 ├── setup.py # 用于安装项目的Python脚本 ├── requirements.txt # 项目依赖列表 ├── .gitignore # Git 忽略文件配置 ├── .env # 环境变量配置文件…

【vue3 + Echarts 】中国地图省市区下钻,并返回上级

实现效果如果&#xff1a; echarts版本&#xff1a; 地图数据来源&#xff1a;阿里云数据可视化平台 代码 <template><div class"mapWrapper"><a-button type"primary" click"goBack">返回上级</a-button><div…

一步步实现知乎热榜采集:Scala与Sttp库的应用

背景 在大数据时代&#xff0c;网络爬虫技术发挥着不可或缺的作用。它不仅能够帮助我们快速地获取互联网上的信息&#xff0c;还能处理和分析这些数据&#xff0c;为我们提供深刻的洞察。知乎&#xff0c;作为中国领先的问答社区&#xff0c;汇聚了各行各业的专家和广大用户的…

深入解析力扣172题:阶乘后的零(计算因子5的方法详解及模拟面试问答)

在本篇文章中&#xff0c;我们将详细解读力扣第172题“阶乘后的零”。通过学习本篇文章&#xff0c;读者将掌握如何使用多种方法来解决这一问题&#xff0c;并了解相关的复杂度分析和模拟面试问答。每种方法都将配以详细的解释和ASCII图解&#xff0c;以便于理解。 问题描述 …

【LeetCode刷题】二分查找:寻找旋转排序数组中的最小值、点名

【LeetCode刷题】Day 14 题目1&#xff1a;153.寻找旋转排序数组中的最小值思路分析&#xff1a;思路1&#xff1a;二分查找&#xff1a;以A为参照思路2&#xff1a;二分查找&#xff0c;以D为参照 题目2&#xff1a;LCR 173.点名思路分析&#xff1a;思路1&#xff1a;遍历查找…

(2024,Flag-DiT,文本引导的多模态生成,SR,统一的标记化,RoPE、RMSNorm 和流匹配)Lumina-T2X

Lumina-T2X: Transforming Text into Any Modality, Resolution, and Duration via Flow-based Large Diffusion Transformers 公和众和号&#xff1a;EDPJ&#xff08;进 Q 交流群&#xff1a;922230617 或加 VX&#xff1a;CV_EDPJ 进 V 交流群&#xff09; 目录 0. 摘要 …