vue3 websocket连接上了,会自动断开的处理的二种方式

15 篇文章 0 订阅
1 篇文章 0 订阅

上了服务器以后,发现websocket会自动断开,那么我们可以有二种方法:

1)一般我们会发送心跳包

function sendMessagePing() {
    if (websocket && websocket.readyState === WebSocket.OPEN) {
      websocket.send('ping');
    } else {
      console.log('WebSocket连接已断开~');
    }
  }

然后我们在setInterval来定时去调用上面的方法:

var timerInterval = setInterval(() => {
      sendMessagePing();
    }, 1000);


// unmounted
clearInterval(timerInterval);

上面是每隔1秒钟去发一次ping给服务器,然后服务器收到了不进行处理,也可以有输出。

这里是spring boot的代码,用于接收前端发过来的消息。:

  //前端向后端发送消息
    @OnMessage
    public void onMessage(String message) {
        if (!message.equals("ping")) {
            System.out.println("【websocket消息】收到客户端发来的消息:"+message);
        }
    }

2、也可以通过配制超时时间来处理:

proxy_read_timeout 5;

只要延长proxy_read_timeout也是可以的。

还是方式1比较合理,有些时间nginx配制,前端开发是接触不到的。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值