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';
    }
相关推荐
踩着两条虫34 分钟前
AI驱动的Vue3应用开发平台深入探究(十):物料系统之内置组件库
android·前端·vue.js·人工智能·低代码·系统架构·rxjava
慧一居士1 小时前
nuxt3 项目和nuxt4 项目区别和对比
前端·vue.js
神舟之光3 小时前
jwt权限控制简单总结(乡村意见簿-vue-express-mongdb)
前端·vue.js·express
晏宁科技YaningAI3 小时前
全球短信路由系统设计逻辑打破 80%送达率瓶颈:工程实践拆解
网络·网络协议·架构·gateway·信息与通信·paas
流光墨佰4 小时前
我做了一个专为油猴打造的轻量级 Vue 组件注入库
vue.js
WIN-U64 小时前
新版华三H3C交换机配置NTP时钟步骤 示例(命令及WEB配置)
网络协议·tcp/ip·http
F1FJJ4 小时前
什么是 Shield CLI?视频讲解:一条命令,可浏览器远程访问一切内部服务(RDP/VNC/SSH/数据库等)
运维·网络·数据库·网络协议·ssh
F1FJJ5 小时前
Shield CLI 命令全解析:15 个命令覆盖所有远程访问场景
网络·数据库·网络协议·容器·开源软件
nbsaas-boot8 小时前
基于 HTTP 构建 MCP Tools 的完整工程解析
网络·网络协议·http·ai
i建模8 小时前
SSL: CERTIFICATE_VERIFY_FAILED feishu 机器人CoPaw
运维·网络·网络协议·ssl·openclaw