sockjs-client和stompjs连接websocket服务被拒绝导致vue项目崩溃问题

1、前端连接服务器代码demo:

javascript 复制代码
// 引入stomp.js库
import SockJS from 'sockjs-client';
import Stomp from 'stompjs';

// WebSocket服务器地址
const ws = new SockJS('http://localhost:8080/my-endpoint');

// 初始化STOMP客户端
const stompClient = Stomp.over(ws);

// 连接STOMP服务器
stompClient.connect({}, frame => {
    console.log('Connected: ' + frame);

    // 订阅一个路径
    stompClient.subscribe('/topic/greetings', message => {
        console.log(JSON.parse(message.body).content);
    });
}, error => {
    console.error('STOMP error:', error);
});

// 发送消息到服务器
stompClient.send("/app/hello", {}, JSON.stringify({ 'name': 'John Doe' }));

// 断开连接
stompClient.disconnect();

2、崩溃主要原因

  • 未捕获的异常:在JavaScript(以及Vue.js这样的框架)中,如果发生一个异常且没有被任何try...catch语句捕获,那么异常会冒泡至全局作用域,导致整个应用崩溃。Vue.js自身不会捕获这些异常,因为它们是在应用代码中产生的。
  • 错误冒泡:在JavaScript中,错误冒泡到全局作用域通常指的是当一个错误在代码中被抛出(throw),并且没有被任何内部的try...catch语句捕获时,这个错误会沿着调用栈向上传播,最终到达全局作用域。如果全局作用域也没有错误处理机制,那么这个错误通常会导致整个应用崩溃,因为JavaScript引擎不知道如何继续执行后续的代码。具体来说,当函数内部发生错误时,如果这个函数没有包含try...catch块来捕获这个错误,那么错误会被传递给调用该函数的代码。如果这个调用代码也没有捕获错误,那么错误会继续向上冒泡,直到到达最顶层的全局作用域。冒泡到全局作用域的错误通常会导致浏览器控制台显示错误信息,并且可能会中断正在执行的JavaScript代码,导致应用界面停止响应或变得不可用。在单页面应用(SPA)如Vue应用中,这种全局错误可能会导致整个应用的UI停止更新或行为异常。

3、解决方式:因为当前版本的socketjs内部没有捕捉连接失败抛出的异常,所以最好的解决方式就是对websocket服务器进行健康检查,如果请求服务器有响应说明没挂进行连接,否则就舍弃websocket相关应用,舍车保帅,保证nodejs服务的正常运行。

java 复制代码
	@GetMapping("/health")
    public Health health() {
        return 'ok';
    }
相关推荐
sweet丶42 分钟前
MQTT在iOS中的应用实践
网络协议
ALINX技术博客43 分钟前
【黑金云课堂】FPGA技术教程Vitis开发:TCP以太网通信
网络协议·tcp/ip·fpga开发
云水一下1 小时前
Vue.js从零到精通系列(三):组件化基础——Props、Emits、插槽与生命周期
前端·javascript·vue.js
W.W.H.3 小时前
Ping 与 TCP:网络连通性探测的两种维度
网络·网络协议·tcp/ip
英勇无比的消炎药3 小时前
少踩坑TinyVue插槽事件编码规范详解
vue.js
IpdataCloud3 小时前
担心IP查询泄露隐私?用离线查询工具安全查IP,数据不出内网
网络协议·tcp/ip·安全
码农飞哥4 小时前
RocketMQ消费接口设计实战:为什么HTTP回调接口必须吞掉所有异常,始终返回成功?
网络协议·http·中间件·消息队列·rocketmq
行走__Wz4 小时前
【网工入门-04】局域网、城域网、广域网
网络协议
2401_868534784 小时前
5G和4G接入网对比介绍
vue.js
白露与泡影4 小时前
为什么 RPC 要比 HTTP 更快?我:之前项目只用过 HTTP...
网络协议·http·rpc