WebSocket 实现断线重连 详细代码 项目源码

小项目源码https://gitee.com/chen_yan_ting/web-socket_dou_di_zhu
实现原理:
WebSocket的onClose 连接关闭回调方法webSocket.onclose()
重新新建WebSocket() 建立一个连接 但是连接参数一模一样和原来的一模一样
后端的OnOpen()方法创建新的session 找到客户端对应对象 把对象里面的session替换成新的就实现重连了

//连接关闭回调方法
webSocket.onclose = function () {
     console.log("连接关闭")
     console.log("尝试重连")
     reconnecting()
}
function reconnecting() {       
	webSocket = new WebSocket("ws://" + ip + ":9000/api/websocket/" + roomid + "/" + sid);
	      //监听服务器发送的消息
	webSocket.onmessage = function (e) {
	      // console.log("收到消息");
	      // console.log(e.data);
	      if (e.data[0] === 'P') {
	          parsePoker(e.data);
	      }
	      if (e.data[0] === 'W') {
	          win(e.data)
	      }
	  }
	//连接关闭回调方法
	webSocket.onclose = function () {
	   console.log("连接关闭")
	   console.log("尝试重连")
	   reconnecting()
	}
}

后端WebSocket的@OnOpen方法监控连接建立

@OnOpen
public void onOpen(Session session, @PathParam("roomid") String roomid, @PathParam("sid") String sid) {

每次连接建立都会有一个新的Session,这个Session就是和相应客户端通信的关键

 // 存放每个客户端对应的MWebSocketServer对象
 private static CopyOnWriteArraySet<WebSocketServer> webSocketSet = new CopyOnWriteArraySet<>();

CopyOnWriteArraySet 用于存储所有连接的客户端
所以可以遍历webSocketSet 通过重新建立连接传来的sid匹配原来断开连接的WebSocketServer 把WebSocketServer里面的session替换成新的session

for (WebSocketServer item : webSocketSet) {
	// 找对应的客户端的对象 里面存着对应客户端的数据
   if (item.roomid.equals(roomid) && item.sid.equals(sid) {
        System.out.println("重连运行");
        // 数据不变 只改session 就是通信变了
        item.session = session;
        reconnect = true;
    }  
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lolxxs

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值