spring mvc + tomcat 实现 websocket 异常 connection abort: socket write error

本文所使用的技术为spring mvc + tomcat7实现的tomcat技术,在刷新页面后出现异常

  • 错误关键字

    java.util.concurrent.ExecutionException: java.net.SocketException:
    Software caused connection abort: socket write error]

  • 异常方法为:public void handleTransportError(WebSocketSession webSocketSession, Throwable e)
    throws Exception {}
    如下图:

spring mvc + tomcat 实现 websocket 异常 connection abort: socket write error_第1张图片

  • 运行报错日志如下:
22:26:46.360 [http-bio-8080-exec-2] ERROR com.webchat.websocket.ChatWebSocketHandler -  [] 
java.net.SocketException: Software caused connection abort: socket write error] 


22:26:46.361 [http-bio-8080-exec-2] ERROR com.webchat.websocket.ChatWebSocketHandler -  
[] [websocket 连接异常2,:->Message will not be sent because the WebSocket session has been closed]
  • 解决方案为:
    在html网页中加入监听窗口事件后关闭websocket连接的函数
            window.onbeforeunload = function(event) {
                ws.onclose =function(){};
                ws.close();
            }

原因分析:

  • 该问题主要发生在页面刷新的时候,ws连接实际已经断开,但前后台均为做断开操作,后台一直保持连接,待前端断开后,却没有释放掉该连接,故后台还在有状态的监听使用故报错。

  • 另连接时间过长浏览器自动切断时也会出现此问题

你可能感兴趣的:(+++++Java+++++)