node + express + sockio 在线聊天室

整个代码结构很明了, 一个启动server.js,一个socket.js, 剩下的就是页面的js,和css。

服务端代码很简单,大概几十行。

/************************************************************/

server.js

-------------------------

let express = require('express');
let app = express();

app.use(express.static(__dirname + '/client'));

// 监听3000端口
const server = app.listen(3000, function () {
const host = server.address().address;
const port = server.address().port;

console.log('http://%s:%s', host, port, ',启动成功');
});

const socket = require('./socket');

socket(server);

/************************************************************/

socket.js

-------------------------

module.exports = (server) => {

let io = require('socket.io')(server);

/**
* 在线人员
*/

let onLineUsers = {};

/**
* 在线人数
*/

let onLineCounts = 0;

/**
* io监听到存在链接,此时回调一个socket进行socket监听
*/

io.on('connection', function (socket) {
console.log('a user connected');
/*监听新用户加入*/
socket.on('login', function (user) {
//暂存socket.name 为user.userId;在用户退出时候将会用到
socket.name = user.userId;
/*不存在则加入 */
if (!onLineUsers.hasOwnProperty(user.userId)) {
//不存在则加入
onLineUsers[user.userId] = user.userName;
onLineCounts++;
}

/**
* 一个用户新加入,向所有客户端监听login的socket的实例发送响应,响应内容为一个对象
*/

io.emit('login', {
onLineUsers: onLineUsers,
onLineCounts: onLineCounts,
user: user
});
console.log(user.userName, "加入了聊天室"); //在服务器控制台中打印么么么用户加入到了聊天室
});

/**
* 监听用户退出聊天室*
*/

socket.on('disconnect', function () {
if (onLineUsers.hasOwnProperty(socket.name)) {
let user = {
userId: socket.name,
userName: onLineUsers[socket.name]
};
delete onLineUsers[socket.name];
onLineCounts--;

/**
* 向所有客户端广播该用户退出群聊
*/

io.emit('logout', {
onLineUsers: onLineUsers,
onLineCounts: onLineCounts,
user: user
});
console.log(user.userName, "退出群聊");
}
})
/*监听到用户发送了消息,就使用io广播信息,信息被所有客户端接收并显示。注意,如果客户端自己发送的也会接收到这个消息,故在客户端应当存在这的判断,是否收到的消息是自己发送的,故在emit时,应该将用户的id和信息封装成一个对象进行广播*/
socket.on('message', function (obj) {
/*监听到有用户发消息,将该消息广播给所有客户端*/
io.emit('message', obj);
console.log(obj.userName, "说了:", obj.content);
});
});
}






github地址:

https://github.com/chenzezhang/NodeSockio

欢迎大家多多提


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值