websocket链接及调试

本文详细介绍如何在Spring Boot项目中配置并使用WebSocket实现即时通讯功能,包括添加依赖、配置类、创建WebSocket类及测试方法。

1.pom文件添加websocket依赖

<!--webSocket依赖-->
<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-websocket</artifactId>
</dependency>
<dependency>
   <groupId>org.apache.tomcat.embed</groupId>
   <artifactId>tomcat-embed-websocket</artifactId>
</dependency>

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-websocket</artifactId>
   <exclusions>
      <exclusion>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-logging</artifactId>
      </exclusion>
   </exclusions>
</dependency>

2.创建WebSocketConfig类文件

package XXX.websocket;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.socket.config.annotation.EnableWebSocket;
import org.springframework.web.socket.server.standard.ServerEndpointExporter;
@EnableWebSocket
@Configuration
public class WebSocketConfig {
   @Bean
   public ServerEndpointExporter serverEndpointExporter() {
      return new ServerEndpointExporter();
   }
}

3.创建WebSocket文件

package XXX.websocket;

import org.springframework.stereotype.Controller;

import javax.websocket.OnClose;
import javax.websocket.OnMessage;
import javax.websocket.OnOpen;
import javax.websocket.Session;
import javax.websocket.server.PathParam;
import javax.websocket.server.ServerEndpoint;
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.CopyOnWriteArraySet;

//注意是controller注解
@Controller
@ServerEndpoint("/websocket/{tableId}")
public class WebSocket {
   private Session session;
   public static CopyOnWriteArraySet<WebSocket> webSockets = new CopyOnWriteArraySet<>();
   private static Map<String, Session> sessionPool = new HashMap<String, Session>();

   @OnOpen
   public void onOpen(Session session, @PathParam(value = "tableId") String code) {
      this.session = session;
      webSockets.add(this);
      sessionPool.put(code, session);
      // Constants.WEBSOCKET = true;//定义常量  是否开启websocket连接
      System.out.println("【websocket消息】有新的连接,总数为:" + webSockets.size());
   }

   @OnClose
   public void onClose() {
      webSockets.remove(this);
      //Constants.WEBSOCKET = false;
      System.out.println("【websocket消息】连接断开,总数为:" + webSockets.size());
   }

   @OnMessage
   public void onMessage(String message) {
      System.out.println("【websocket消息】收到客户端消息:" + message);
   }

   // 此为广播消息
   public void sendAllMessage(String message) {
      for (WebSocket webSocket : webSockets) {
         System.out.println("【websocket消息】广播消息:" + message);
         try {
            webSocket.session.getAsyncRemote().sendText(message);
         } catch (Exception e) {
            e.printStackTrace();
         }
      }
   }

   // 此为单点消息
   public void sendOneMessage(String code, String message) {
      Session session = sessionPool.get(code);
      System.out.println(code);
      /*在发送数据之前先确认 session是否已经打开 使用session.isOpen() 为true 则发送消息
       * 不然会报错:The WebSocket session [0] has been closed and no method (apart from close()) may be called on a closed session */
      if (session != null && session.isOpen()) {
         try {
            session.getAsyncRemote().sendText(message);
         } catch (Exception e) {
            e.printStackTrace();
         }
      }
   }
}

4.springBoot启动类上添加注解进行启动

@EnableDiscoveryClient

5.添加推送接口

@Autowired
private WebSocket webSocketServer;


// @Inner(value = false)
@PostMapping("/pushCarWarningInfo")
public R pushCarWarningInfo(String message,String license) {
   webSocketServer.sendAllMessage(message);
   return R.ok(message);

}

6.测试页面html添加socket链接

socket = new WebSocket("ws:127.0.0.1:9003/websocket/12311");

7.打开页面,看是否socket open

8.给接口发送消息,看页面是否正常接收显示

### WebSocket 调试方法与工具推荐 调试 WebSocket 时,选择合适的工具和方法可以显著提高开发效率。以下是几种常用的方法和工具推荐: #### 方法一:使用浏览器开发者工具 现代浏览器(如 Chrome、Firefox)内置的开发者工具支持 WebSocket 调试功能。通过打开开发者工具中的“网络”选项卡,可以查看 WebSocket 的连接状态以及发送和接收的消息内容[^3]。 #### 方法二:使用专门的 WebSocket 调试工具 专用的 WebSocket 调试工具有助于更深入地测试和验证 WebSocket 连接的功能和性能。以下是一些推荐的工具: - **Apifox** Apifox 是一款集成了 HTTP 和 WebSocket 调试功能的工具,用户界面友好且功能强大。它能够帮助开发者轻松完成 WebSocket 的连接测试和消息收发验证[^1]。 - **WebSocket调试工具** 这是一款绿色软件,无需安装任何插件即可使用。支持 ASCII 和 Hex 码的收发与显示,同时提供单次发送、多次发送和循环发送等多种模式。此外,还支持 Binary 和 Text 传送模式,适合多种调试场景[^2]。 - **在线 WebSocket 测试工具** 对于需要快速验证 WebSocket 功能的开发者,可以使用在线测试工具。例如,https://www.ewbang.com/websocket/index.html 提供了一个简单的用户界面,用于测试 WebSocket 的连接和消息交互。 #### 方法三:编写自定义测试脚本 如果需要更灵活的调试方式,可以编写自定义的测试脚本来模拟客户端行为。以下是一个基于 Python 的简单示例代码: ```python import websocket def on_message(ws, message): print(f"Received: {message}") def on_error(ws, error): print(f"Error: {error}") def on_close(ws, close_status_code, close_msg): print("WebSocket closed") def on_open(ws): print("WebSocket opened") ws.send("Hello, Server!") # 配置 WebSocket 客户端 ws = websocket.WebSocketApp( "ws://example.com/socket", on_message=on_message, on_error=on_error, on_close=on_close ) ws.on_open = on_open # 启动 WebSocket 客户端 ws.run_forever() ``` 上述代码展示了如何使用 `websocket-client` 库创建一个简单的 WebSocket 客户端,并处理消息收发、错误和关闭事件[^4]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值