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

一、开发工具

后端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
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
部署 WebSocket 服务器通常有两种方法: 1. 将 WebSocket 服务器直接部署在应用服务器中,如 Tomcat、Jetty 等,这种方式需要在应用服务器中添加 WebSocket 支持的插件或者模块。 2. 使用独立的 WebSocket 服务器,如 Netty、Undertow 等,这种方式需要将 WebSocket 服务器独立部署,并将 WebSocket 服务器和应用服务器进行集成。 以下是基于 Spring BootWebSocket 服务器部署步骤: 1. 添加 Spring Boot WebSocket 依赖: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-websocket</artifactId> </dependency> ``` 2. 创建 WebSocket 配置类,并添加 @EnableWebSocket 注解: ``` @Configuration @EnableWebSocket public class WebSocketConfig implements WebSocketConfigurer { @Override public void registerWebSocketHandlers(WebSocketHandlerRegistry registry) { registry.addHandler(new MyWebSocketHandler(), "/websocket").setAllowedOrigins("*"); } } ``` 3. 创建 WebSocket 处理器: ``` public class MyWebSocketHandler extends TextWebSocketHandler { @Override public void handleTextMessage(WebSocketSession session, TextMessage message) throws Exception { String payload = message.getPayload(); session.sendMessage(new TextMessage("Received: " + payload)); } } ``` 4. 在应用程序中注入 WebSocket 处理器: ``` @Controller public class WebSocketController { @Autowired private MyWebSocketHandler webSocketHandler; @GetMapping("/websocket") public String websocket() { return "websocket"; } } ``` 5. 编写前端页面,使用 WebSocket 进行连接: ``` var socket = new WebSocket('ws://localhost:8080/websocket'); socket.onmessage = function(event) { console.log('Received: ' + event.data); } socket.send('Hello, Server!'); ``` 6. 运行应用程序,并访问 http://localhost:8080/websocket 页面,打开浏览器控制台查看 WebSocket 连接状态。 以上是基于 Spring BootWebSocket 服务器部署步骤,具体实现可以根据自己的需求进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值