Node.js 学习(六)——websocket 组件实现在线聊天室 demo

贫寒豌豆

共 1791字,需浏览 4分钟

 ·

2017-04-26 17:01

Node.js学习(六)——websocket组件实现在线聊天室demo

要实现的功能

  1. 在线人员列表展示,上下线刷新在线人员列表
  2. 即时聊天

demo图片

用express新建项目

express -e websocketdemo

下载依赖

在websocketdemo目录下执行命令,在项目下生成node_modules目录

npm install

添加websocket模块

npm install nodejs-websocket

实现代码

项目目录

在view下添加一个chartroom.ejs页面




    
    聊天室
    
    


当前登录人:

index.js修改

  1. 添加跳转到页面的路由
  2. 添加websocket服务器
  3. 服务器中3种类型的逻辑处理
  4. code=0,代表初始化客户端请求。1.将当前连接放入在线人集合中。2.向所有在线人发出更新在线人的消息。
  5. code=1,代表发送消息。将所有在线人的消息界面追加上当前发送的消息。
  6. code=2,代表人员列表更新。上线是新增一个在线人员,下线或刷新浏览器是减少一个在线人员。
var express = require('express');
var router = express.Router();
var ws = require("nodejs-websocket");
//存所有人的连接
var onLineUser = new Array();

/* GET home page. */
router.get('/', function(req, res, next) {
  res.render('index', { title: 'Express' });
});

//聊天室页面
router.get('/chartroom', function(req, res, next) {
  res.render('chartroom');
});

//聊天服务器8002
var server = ws.createServer(function (conn) {
  conn.on("text", function (str) {
    var obj = JSON.parse(str);
    switch(obj.code){
      case 0:initClient(conn);break;
      case 1:returnMsg(conn,obj);break;
      case 2:userListHandle(conn,obj);break;
    }
  })
  conn.on("close", function (code, reason) {
    console.log("关闭连接")
  });
  conn.on("error", function (code, reason) {
    console.log("异常关闭")
  });
}).listen(8002)

//发送消息,返回消息
function returnMsg(conn,obj){
  if(userList.length != 0){
    var returnText = obj.name+" "+obj.date+":\n"+"  "+obj.sendContent+"\n";
    var returnObj = new Object();
    returnObj.code = 1;
    returnObj.returnText=returnText;
    for(var i=0;i -1) {
    this.splice(index, 1);
  }
};

module.exports = router;
浏览 42
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报