Nodejs +Websocket如何实现指定发送及群聊
这篇文章主要介绍了Nodejs +Websocket如何实现指定发送及群聊,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
目的
通过nodejs + ws (Websocket) 实现点对点发送及群聊发送项目搭建直接跳过,这里列举一下用到的插件 yarn add ws
WebSocket
话不多说,直接上码
对比上一篇文章 << Nodejs+MongoDB 搭建服务( demo ) >> server.js 主要是增加了ws的引用,webSocket 点对点也好,群聊也好,主要是用到一个方法 clients 它的作用就是存储了连接,我们可以通过对每一个连接增加标识,然后根据接收到的信息进行解析,遍历然后发送正确的响应。
先解析下代码(小声BB), 下面会有HTML页面
nbs.on("connection",(ws,req)=>{ ws.on("message",message=>{ //这里解析数据 constresult=JSON.parse(message); //是否是登陆,登陆后绑定id if(result.login){ ws.socketIdxos=result.id; }else{ //这里只做一个小的场景,不是登陆就是发送信息 //根据存储的id是否是要发送的对象来单独响应 nbs.clients.forEach(s=>{ if(s.socketIdxos==result.to&&s.readyState==1){ s.send(JSON.stringify({data:result.mes})); } }); } }); ws.on("close",message=>{ console.log(ws.socketIdxos,"退出连接"); }); });
HTML
这里我分别建了三个页面其中两个模拟用户,一个模拟群聊
这是BBB用户,另一个页面是 AAA 只是改了下信息而已,就不都贴上来了,很简单
<!DOCTYPEhtml> <html> <head> <metacharset="utf-8"> <title>BBB111</title> <script> constws=newWebSocket("ws://localhost:8181"); ws.onopen=function(e){ ws.send(JSON.stringify({ "id":"BBB111", "login":true, })); } functionsendMessage(){ ws.send(JSON.stringify({ "id":"BBB111",//当前ID "login":false,//是否登陆 "to":"AAA111",//发送对象 "mes":"我是BBB111,这是发送给AAA111的消息"//发送内容 })); } functionsendYUYUYU(){ ws.send(JSON.stringify({ "id":"BBB111", "login":false, "to":"YUYUYU", "mes":"我是BBB111,这是到群里的消息" })); } ws.onmessage=function(e){ console.log(e,"eeee-"); } </script> </head> <body> <buttononclick="sendMessage();">发送</button> <buttononclick="sendYUYUYU();">群聊</button> </body> </html>
下面的是只用来接收的群页面,更简单
<!DOCTYPEhtml> <html> <head> <metacharset="utf-8"> <title>群聊</title> <script> constws=newWebSocket("ws://localhost:8181"); ws.onopen=function(e){ //这里主要作用就是注册下群成立了...... ws.send(JSON.stringify({ "id":"YUYUYU", "login":true, })); } ws.onmessage=function(e){ console.log(e,"eeee-"); } </script> </head> <body> </body> </html>
展示
constws=newWebSocket("ws://localhost:8181"); localhost可以换成的你的本机IP,这样页面在其他电脑也可以发送到你的页面上
可以看到,在BBB的页面,接收到了AAA发送的信息
无论是AAA发送的群里信息,还是BBB发送的群里信息,在群聊页面都是可以看到的
感谢你能够认真阅读完这篇文章,希望小编分享的“Nodejs +Websocket如何实现指定发送及群聊”这篇文章对大家有帮助,同时也希望大家多多支持恰卡编程网,关注恰卡编程网行业资讯频道,更多相关知识等着你来学习!
推荐阅读
-
NodeJS怎么实现单点登录
-
怎么用Vue+NodeJS实现大文件上传
-
node中的buffer有什么用
node中的buffer有什么用本文小编为大家详细介绍“node中...
-
node中multer的概念是什么
node中multer的概念是什么这篇文章主要介绍“node中mu...
-
nodejs怎么读取文件夹目录的内容
nodejs怎么读取文件夹目录的内容小编给大家分享一下nodejs...
-
nodejs如何结合socket.io实现websocket通信功能
这篇文章主要介绍nodejs如何结合socket.io实现websocket通信功能,文中介绍的非常详细,具有一定的参考价值,感兴...
-
nodejs如何结合Socket.IO实现的即时通讯功能
-
nodejs如何实现TCP服务器端和客户端聊天功能
这篇文章主要介绍了nodejs如何实现TCP服务器端和客户端聊天功能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇...
-
Nodejs能够应用于什么场景
这篇文章给大家分享的是有关Nodejs能够应用于什么场景的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。...
-
NodeJs内存占用过高如何排查