socket.io 连接与断开连接

1. 服务端

监听connection 事件

io.sockets.on('connection', (socket) => {
    console.log("connection socket:", socket.handshake.query.username)
	
	// 监听断开事件
	socket.on('disconnect', (reason) => {
            console.log("disconnect reason ", reason)
            //userMap.delete(socket.handshake.query.username)
    })
}

这里通过socket.handshake.query 可以查看一些请求参数,对连接做一些限制,不符合条件的就拒掉

2. 客户端

var username = document.querySelector('input#username')
// connect
socket = io.connect('', { query: "username=" + username.value });

// 30 秒后主动断开连接
setTimeout(function () {
        socket.disconnect()
    }, 30000)

io.connect 接口,第一个参数是请求url,第二个参数是相关参数,这里携带用户名

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值