springboot+websocket及部署tomcat后404问题的处理

本文介绍了在SpringBoot项目中使用WebSocket,并在Vue前端进行集成的配置方法。在开发环境中,通过PROXY_HOST代理解决跨域问题。在部署到Tomcat时遇到404错误,原因是WebSocketConfig类在生产环境中不需要。最后,解决了WebSocket握手失败的问题,通过判断环境动态添加项目名到WebSocket URL。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、开发工具

后端intellij,前端vscode,部署环境tomcat9

二、前端vue+websocket

1、在系统主页Main.vue中初始化和关闭websocket,相关的js放在websocket.js文件中
**Main.vue**
import {
   
   initWebSocket,closeWebSocket} from '@/commons/websocket.js';

created(){
   
   
	initWebSocket();
}
destroyed(){
   
   
    closeWebSocket();
}
websocket.js
内容在网上都可以找到这里只记录一下重点。
1)接收到数据后如何在其他vue里使用,采用记录到store,使用的页面进行监听
**websocket.js**
import store from '@/store';
onmessage=(event)=>{
	var message = JSON.parse(event.data);
	 //publishinfo为store里action里定义的函数
	store.dispatch("publishInfo", message);
}

**store的app.js里**
actions: {
    publishInfo(store,info){
    	//在store的state定义好变量message
        store.state.message = info;
    }
}
**其他需要使用数据的页面**
computed:{
	publishInfo(){
            return this.$store.state.app.message;
    }
},
watch:{
	publishInfo(message){
		业务代码...
	}
}
2)访问后端的websocket的url,在vscode中启动项目的话访问不需要加项目名,在tomcat里启动访问项目的话需要加上项目名,所以在此进行处理,开发环境为空,打包时会加上项目名。
**websocket.js**
const getWsUrl = () => {
var host = serverHost(); //window.location.host
var project = process.env.API_ROOT;
if(process.env.NODE_ENV === "development"){
    host = process.env.PROXY_HOST;
    project = "";
}
return "ws://" + host + project +"/websocket/" + getContext().user.id;

}
config/dev.env.js
加了PROXY_HOST: ‘“localhost:8888”’

二、springboot+websocket

pom.xml加入

<!-- spring boot websocket 依赖包 -->
   <
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值