Node.js——仿微信网页版搭建聊天室(一)

在实现聊天室你必须要用到的文件

通过npm install socket.io命令获取到socket.io模块

服务器端

www:


var io=require('socket.io').listen(server);  global.io=io;                                //将io提升为全局变量

var ioServer=require('../db/ioServer')();    //将io的connection操作放至该文件下,避免www文件过于臃肿

客户端

头文件引入socket.io.js文件


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

客户端与服务器端实现连接

首先需要知道的API

io.on('connection',function(socket));

监听客户端连接,回调函数会传递本次连接的socket

io.sockets.emit('String',data);

给所有客户端广播消息

io.sockets.socket(socketid).emit('String', data);

给指定的客户端发送消息

socket.on('String',function(data));

监听客户端发送的信息,同样也可以用于客户端监听服务器发送的信息

socket.emit('String', data);

给该socket的客户端发送消息,同样也可以用于向服务器发送消息

客户端如何与服务器端建立连接

var socket=io.connect('http://localhost:3000');       

//与localhost:3000发送建立连接的消息

socket.on("open",function() {

     socket.emit("addUser",$("#findName").text());

})

//服务器端收到建立连接的消息后,返回一个open信息,标志着服务器与客户端建立连接

//在两者建立连接后,客户端接着发送addUser请求,并将客户端账号的名字作为参数传输过去

服务器端如何响应客户端建立连接的请求

var client={};

//client对象以客户端的用户的名字为标志,存储对应的socket

io.on('connection',function(socket) {

    //注:下文中在服务器端中的任何socket方法都是在connection中实现的

    socket.emit('open');

    //通知客户端已连接

    socket.on("addUser",function(username) {

        client[username]=socket;

        name=username;

        //name为该connection方法下标志的socket所对应的客户端的名字,用户离线时会用到

    })

    //服务器端接收到客户端的addUser请求后,将io.on('connection',function(socket){})返回的socket赋值给对应的client[username]

}

服务器端如何处理客户端断开连接


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

    delete client.name;

    //当用户离线时,删除client对象中的name属性以及相关的值

})

客户端与服务器端实现一对一即时聊天

客户端所进行的操作

varsend=$(".send-message").children("button");

//发消息按钮

send.on('click',function() {

    var message=input.val();

    var receiver=$(".onChat").children("span").text();

    var poster=$("#findName").text();

    var obj={

        message:message,

        receiver:receiver,

        poster:poster

     }

    //客户端发送的obj对象里面,message表消息,receiver表消息的接收方,poster表消息的发送方,即客户端自己

     if(!message)return;

     //信息不存在则结束函数

     socket.send(obj);

    //向服务器端发送obj对象,被服务器端的socket.on('message',function(obj) {}方法接受

     input.val('');

})

socket.on('message',function(obj) {

    //message方法表示接收到来自他人的消息,或者是自己发送到服务器端的obj的到了服务器的回应(表示发送消息成功),obj则是服务器端原封不动的将信息将上文的obj对象传输给客户端

    handleMsg(obj);

    //用于在网页更新数据,根据poster与当前客户端的用户名称的关系判断该消息的发送方是否是自己再进行相关操作

    //由于网页更新数据不同人有不同方法,略去

}

服务器端进行的操作

socket.on('message',function(obj) {

    //这一部分尚未涉及数据库的存储,该内容之后会写

    if(client.hasOwnProperty(obj.receiver)){

    //如果消息的接收方不在线,则不发送obj

        client[obj.receiver].emit('message',obj);

    }

    socket.emit('message',obj);

    //向客户端返回message消息,表示发送成功,虽然暂时未通过数据库实现离线发送,但还是默认消息发送成功:);

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,884评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,755评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,369评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,799评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,910评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,096评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,159评论 3 411
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,917评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,360评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,673评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,814评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,509评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,156评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,123评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,641评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,728评论 2 351

推荐阅读更多精彩内容