当前位置: 首页 > 编程笔记 >

nodejs实现的一个简单聊天室功能分享

缑桐
2023-03-14
本文向大家介绍nodejs实现的一个简单聊天室功能分享,包括了nodejs实现的一个简单聊天室功能分享的使用技巧和注意事项,需要的朋友参考一下

今天我来实现一个简单的聊天室,后台用nodejs, 客户端与服务端通信用socket.io,这是一个比较成熟的websocket框架.

初始工作

1.安装express, 用这个来托管socket.io,以及静态页面,命令npm install express --save,--save可以使包添加到package.json文件里.
2.安装socket.io,命令npm install socket.io --save.

编写服务端代码

首先我们通过express来托管网站,并附加到socket.io实例里,因为socket.io初次连接需要http协议


var express = require('express'),

    io = require('socket.io');

var app = express();

app.use(express.static(__dirname));

var server = app.listen(8888);

var ws = io.listen(server);


添加服务器连接事件,当客户端连接成功之后,发公告告诉所有在线用户,并且,当用户发送消息时,发广播通知其它用户.

ws.on('connection', function(client){

    console.log('\033[96msomeone is connect\033[39m \n');

    client.on('join', function(msg){

        // 检查是否有重复

        if(checkNickname(msg)){

            client.emit('nickname', '昵称有重复!');

        }else{

            client.nickname = msg;

            ws.sockets.emit('announcement', '系统', msg + ' 加入了聊天室!');

        }

    });

    // 监听发送消息

    client.on('send.message', function(msg){

        client.broadcast.emit('send.message',client.nickname,  msg);

    });

    // 断开连接时,通知其它用户

    client.on('disconnect', function(){

        if(client.nickname){

            client.broadcast.emit('send.message','系统',  client.nickname + '离开聊天室!');

        }

    })

})

由于客户端是通过昵称来标识的,所以服务端需要一个检测昵称重复的函数


// 检查昵称是否重复

var checkNickname = function(name){

    for(var k in ws.sockets.sockets){

        if(ws.sockets.sockets.hasOwnProperty(k)){

            if(ws.sockets.sockets[k] && ws.sockets.sockets[k].nickname == name){

                return true;

            }

        }

    }

    return false;

}

编写客服端代码

由于服务端采用第三方websokcet框架,所以前端页面需要单独引用socket.io客户端代码,源文件可以从socket.io模块里找,windows下路径为node_modules\socket.io\node_modules\socket.io-client\dist,这里有开发版和压缩版的,默认引用开发版就行.

前端主要处理输入昵称检查,消息处理,完整代码如下:


<!DOCTYPE html>

<html>

<head>

    <title>socket.io 聊天室例子</title>

    <meta charset="utf-8">

    <link rel="stylesheet" href="css/reset.css"/>

    <link rel="stylesheet" href="css/bootstrap.css"/>

    <link rel="stylesheet" href="css/app.css"/>

</head>

<body>

    <div class="wrapper">

         <div class="content" id="chat">

             <ul id="chat_conatiner">

             </ul>

         </div>

         <div class="action">

             <textarea ></textarea>

             <button class="btn btn-success" id="clear">清屏</button>

             <button class="btn btn-success" id="send">发送</button>

         </div>

    </div>

    <script type="text/javascript" src="js/socket.io.js"></script>

    <script type="text/javascript">

          var ws = io.connect('http://172.16.2.184:8888');           var sendMsg = function(msg){               ws.emit('send.message', msg);           }           var addMessage = function(from, msg){               var li = document.createElement('li');               li.innerHTML = '<span>' + from + '</span>' + ' : ' + msg;               document.querySelector('#chat_conatiner').appendChild(li);

              // 设置内容区的滚动条到底部               document.querySelector('#chat').scrollTop = document.querySelector('#chat').scrollHeight;

              // 并设置焦点               document.querySelector('textarea').focus();

          }

          var send = function(){               var ele_msg = document.querySelector('textarea');               var msg = ele_msg.value.replace('\r\n', '').trim();               console.log(msg);               if(!msg) return;               sendMsg(msg);               // 添加消息到自己的内容区               addMessage('你', msg);               ele_msg.value = '';           }

          ws.on('connect', function(){               var nickname = window.prompt('输入你的昵称!');               while(!nickname){                   nickname = window.prompt('昵称不能为空,请重新输入!')               }               ws.emit('join', nickname);           });

          // 昵称有重复           ws.on('nickname', function(){               var nickname = window.prompt('昵称有重复,请重新输入!');               while(!nickname){                   nickname = window.prompt('昵称不能为空,请重新输入!')               }               ws.emit('join', nickname);           });

          ws.on('send.message', function(from, msg){               addMessage(from, msg);           });

          ws.on('announcement', function(from, msg){               addMessage(from, msg);           });

          document.querySelector('textarea').addEventListener('keypress', function(event){               if(event.which == 13){                   send();               }           });           document.querySelector('textarea').addEventListener('keydown', function(event){               if(event.which == 13){                   send();               }           });           document.querySelector('#send').addEventListener('click', function(){               send();           });

          document.querySelector('#clear').addEventListener('click', function(){               document.querySelector('#chat_conatiner').innerHTML = '';           });     </script> </body> </html>

这里提供完整的代码压缩文件

总结

nodejs是一个好东西,尤其是在处理消息通讯,网络编程方面,天生的异步IO.

 类似资料:
  • 本文向大家介绍NodeJS实现一个聊天室功能,包括了NodeJS实现一个聊天室功能的使用技巧和注意事项,需要的朋友参考一下 看效果 一直说我喜欢卖关子,这次直接看效果: 聊天界面(喜欢的可以自己画一个比较逼真的页面) 前文 先说一下为什么写这个东西,最近不是在写NodeJS知识点的梳理嘛,但是我发现梳理的过程着实无聊的要死,虽然已经快梳理一半了,只是还没发布,这个不重要,重要的是不做点什么东西确实

  • 本文向大家介绍Nodejs实现多房间简易聊天室功能,包括了Nodejs实现多房间简易聊天室功能的使用技巧和注意事项,需要的朋友参考一下 1、前端界面代码   前端不是重点,够用就行,下面是前端界面,具体代码可到github下载。 2、服务器端搭建   本服务器需要提供两个功能:http服务和websocket服务,由于node的事件驱动机制,可将两种服务搭建在同一个端口下。   1、包描述文件:p

  • 本文向大家介绍nodejs和react实现即时通讯简易聊天室功能,包括了nodejs和react实现即时通讯简易聊天室功能的使用技巧和注意事项,需要的朋友参考一下 npx create-react-app socketio-demo 进入socketio-demo目录 运行eject进行拆包,本项目也可以不拆,这是个人习惯。 注意如果运行eject命令最好在项目初始阶段执行,已经开始编写后不要再使

  • 本文向大家介绍Python socket实现简单聊天室,包括了Python socket实现简单聊天室的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了Python socket实现简单聊天室的具体代码,供大家参考,具体内容如下 服务端使用了select模块,实现了对多个socket的监控。客户端由于select在Windows下只能对socket使用,所以使用了多线程来实现对客户端输

  • 简介 Github 地址 本文使用 go 实现了一个多人聊天室,参考文章为 Writing a Chat Server in Go,点击查看中文翻译版。 本文的特点在于:将原始项目分为自底向上的若干个阶段,新手可以一步步地实现系统的不同模块,逐渐掌握相应知识点。源码里有详细的注释,引导你在不看源代码的情况下自己实现相应代码。 本文假设你: 了解 go 语言的基本语法 了解 git 的使用 完成本项

  • 本文向大家介绍python实现简单多人聊天室,包括了python实现简单多人聊天室的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了python实现多人聊天室的具体代码,供大家参考,具体内容如下 刚开始学习python,写了一个聊天室练练手。 Server.py client.py 运行时先启动服务端。进入聊天室先起一个昵称。服务端会向客户端发送当前聊天室内聊天人的列表。一个客户端发出