关于SpringBoot整合WebSocket实现前端进度条遇到的问题

 

一、客户端连接服务器失败 (viewCode: 200)

  1.         背景

    我在做的项目中存在token校验的过程,关于这个过程我当时还不清楚,花了一个晚上去网上搜索了解。简单来讲,对于我们工程来讲,就是客户端初次开启会话与服务端建立连接的时候,后端会根据用户信息、算法.....等系列操作生成一个唯一的token,下次客户端进行请求时会在HttpHeader携带这个token。这样做的目的是校验前后访问服务器的是不是同一个人。 这里附上大佬通俗易懂的解说:彻底理解cookie,session,token - 知乎j​​​​​​​j发展史1、很久很久以前,Web 基本上就是文档的浏览而已, 既然是浏览,作为服务器, 不需要记录谁在某一段时间里都浏览了什么文档,每次请求都是一个新的HTTP协议, 就是请求加响应, 尤其是我不用记住是谁刚刚发…https://zhuanlan.zhihu.com/p/63061864

  2. 问题及解决方法

    不意外的,通过webSocket建立的ws连接建立也需要进行token的校验过程,也就是在请求头中设置token信息。网上看了很多帖子,有说ws是不让设置请求头的,也有给出一些解决方法的。不过本大大后来都没实现,哈哈哈哈!这里附上网上的解决办法:【JavaScript】在websocket里面添加Token_maomaolaoshi的博客-CSDN博客_js websocket请求头websocket协议在握手阶段借用了HTTP的协议,但是在JavaScript websocketAPI中并没有修改请求头的方法。var token='dcvuahsdnfajw12kjfasfsdf34'send发送参数var ws = new WebSocket("ws://" + url + "/webSocketServer");ws.onopen=functio...https://blog.csdn.net/maomaolaoshi/article/details/82593106?utm_source=copy

        附上我的解决办法: 修改项目中设置的http拦截器 ;本质上就是对于所有你手动定义的ws请求都放行,不进行拦截

 当然不同类型的项目拦截器的设定都是不一致的,如果不知道怎么改去问你们项目经理吧,哈哈哈哈哈!

二、ws请求需要传参问题

我选择的是客户端与服务器建立连接之后,客户端主动给后端发送参数信息

在网上也有看到其他方式实现,但是我这边用不来,实现不了,哈哈哈哈哈!

  1. 实现
        downLoadProject(row, index) {
          if (typeof WebSocket === "undefined") {
            alert("您的浏览器不支持socket");
          } else {
            // 实例化socket
            this.socket = new WebSocket(this.path);
            // 监听socket连接
            this.socket.onopen = this.open;
            // 监听socket错误信息
            this.socket.onerror = this.error;
            // 监听socket消息
            this.socket.onmessage = this.getMessage;
            this.socket.onclose = this.close;
          }
        },
        open: function () {
          console.log("socket连接成功");
          let params = {
            projectId: localStorage.getItem("COMMON.RUNTIME.PRJTID"),
            projectCaseId: localStorage.getItem("COMMON.RUNTIME.PRJTCASEID"),
            stageId: localStorage.getItem("COMMON.RUNTIME.STAGEID"),
          };
           
            //通过连接成功后返回的Socket实例,调用其send方法传参给服务器
          this.socket.send(JSON.stringify(params)); 
          注意:客户端与服务器进行信息交互,规定是json格式,所以需要调用JSON.stringify()方法进行转化
    }

    来看一看后端怎么接收:

        //此注解下的方法用于接收前端发送来的Json串
       @OnMessage 
        public void onMessage(Session session, String message) { 
        //message就是前端发送的Json串
            System.out.println("收到客户端发来的消息: " + message + session.getId());
            String token = SESSION_ID_TOKEN.get(session.getId());
            new Thread(new MyThread(webSocketController, token, message)).start();
        }

三、在@onMessage注解里依赖注入失效问题

  1.  背景

在后端接收到前端发送的信息,也就是Json串后。要进行业务逻辑的处理,为了降低耦合性,同时方便使用和管理,我首先想到的就是Spring的IOC -- 控制反转。废话不多说,直接上解决办法:

来源于一个大佬的帖子,但是现在找不到原文了,说声抱歉!! 

     2. 原因


webSocket进行连接传递信息时,需要对多个客户端创建多个实例,而spring默认为单例模式,只有在遇到@Component注解时,会进行一次实例化,而之后服务器为客户端创建的实例中,spring不会进行依赖注入,因此变量为null。

四、线程中依赖注入失败问题

五、WebSocket关闭连接报错

六、WecSocket进行对象传输

七、java实现每隔4秒获取文件下载进度

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Spring Boot 框架支持使用 WebSocket 协议进行通信。可以使用 Spring Boot 的内置支持来配置 WebSocket,也可以使用第三方库如 Spring WebSocket实现 WebSocket 功能。使用 Spring Boot 可以简化 WebSocket 的配置和使用。 ### 回答2: SpringBoot是一个非常流行的Java web框架,而WebSocket则是一种全新的web通信协议,通过 WebSocket 可以实现 Web 页面与服务器的实时双向通信。SpringBootWebsocket模块提供了强大的支持,使得使用 WebSocket 开发项目变得更加容易。 在springboot中使用websocket,首先需要引入SpringWebSocket模块以及对应的STOMP协议的依赖,可以通过在pom.xml中添加以下依赖实现: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-websocket</artifactId> </dependency> ``` 在Spring Boot应用程序中使用WebSocket非常容易,我们可以分为以下几个步骤: 1. 创建一个WebSocket配置类 在WebSocket配置类中,需要添加@EnableWebSocketMessageBroker和@Configuration注解。其中,@EnableWebSocketMessageBroker注解表示开启WebSocket消息代理支持,@Configuration注解表示该类为配置类。 ``` @Configuration @EnableWebSocketMessageBroker public class WebSocketConfig extends AbstractWebSocketMessageBrokerConfigurer { // TODO 添加相关配置 } ``` 2. 配置WebSocket消息代理 在WebSocketConfig中,需要重写configureMessageBroker方法,来配置WebSocket消息代理。在该方法中,需要首先调用enableSimpleBroker方法,它用于配置简单的消息代理,使得订阅者能够订阅消息。 ``` @Override public void configureMessageBroker(MessageBrokerRegistry config) { config.enableSimpleBroker("/topic"); } ``` 3. 配置WebSocket请求路径 在WebSocketConfig中,需要重写registerStompEndpoints方法,来配置WebSocket请求路径。该方法中,需要调用addEndpoint方法,来注册一个WebSocket端点(/chat),供客户端访问。 ``` @Override public void registerStompEndpoints(StompEndpointRegistry registry) { registry.addEndpoint("/chat").withSockJS(); } ``` 4. 编写WebSocket消息处理类 编写一个WebSocket消息处理类,用来处理WebSocket相关的消息和事件。需要在类上添加@Controller注解,同时在方法上添加@MessageMapping注解,用来指定方法处理的消息地址。 ``` @Controller public class ChatController { @MessageMapping("/msg") @SendTo("/topic/messages") public ChatMessage sendMessage(@Payload ChatMessage chatMessage) { return chatMessage; } } ``` 5. 编写WebSocket客户端代码 最后,我们需要编写WebSocket客户端代码来测试WebSocket通信。在客户端代码中,需要先建立与服务器的连接,然后通过WebSocket发送和接收消息。 ``` var socket = new SockJS('/chat'); var stompClient = Stomp.over(socket); stompClient.connect({}, function (frame) { stompClient.subscribe('/topic/messages', function (chatMessage) { console.log(chatMessage); }); }); function sendMessage() { var message = {sender: 'Alice', content: 'Hello!'}; stompClient.send("/app/msg", {}, JSON.stringify(message)); } ``` 以上就是使用SpringBoot开发WebSocket的主要步骤,通过这些步骤,我们可以轻松地开发出基于WebSocket的实时通讯功能。总体来说,SpringBootWebSocket模块提供了强大的支持,使得使用WebSocket开发项目变得更加容易。 ### 回答3: Springboot是一个开源的Java框架,用于创建可扩展的基于RESTful的Web应用程序。其中,Websocket是一种协议,使用在客户端和服务端之间进行实时通信。在Springboot中使用Websocket可以用于实现即时通信、聊天、实时数据交换等功能。 Springboot使用Websocket需要两个方面:客户端代码和服务端代码。在客户端的代码中,需要引入一个websocket库,例如SockJS或Stomp;在服务端的代码中,则需要使用@ServerEndpoint注解,并为Websocket注册处理类。 Websocket使用的过程中,客户端会建立与服务端的一条持久连接,以进行数据交换。在客户端与服务端建立连接之后,可以发送消息到服务端并通过该连接接收来自服务端的消息。 SpringbootWebsocket还支持多个连接的概念,即多个客户端可以与服务端建立多个连接,之间不会相互干扰。 在Springboot中使用Websocket的优点是它提供了一个简便易用的方式来实现低延迟的双向通信,同时又减少了对HTTP请求的频繁使用,从而提升Web应用的性能和效率。 总之,Springboot使用Websocket是一种方便实用的方式,可以省略掉复杂的代码和步骤,同时还可以快速开发多种实时通信功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值