当前位置: 代码迷 >> 综合 >> spring mvc + tomcat 实现 websocket 异常 connection abort: socket write error
  详细解决方案

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

热度:75   发布时间:2023-12-17 10:08:20.0

本文所使用的技术为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 {}
    如下图:

异常方法

  • 运行报错日志如下:
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连接实际已经断开,但前后台均为做断开操作,后台一直保持连接,待前端断开后,却没有释放掉该连接,故后台还在有状态的监听使用故报错。

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