【SpringBoot】集成webSocket

69 阅读2分钟

开启掘金成长之旅!这是我参与「掘金日新计划 · 12 月更文挑战」的第6天,点击查看活动详情

背景

最近有个需求,是要做PC端的消息发送与消息接收并提醒,后端是Springboot,前端页面使用的vue2,经过讨论与沟通,最终就确定了使用webSocket来实现这个需求。

WebSocket介绍

Websocket 协议是HTM5 协议,它的出现解决了客户端发起多个http 请求到服务器的资源浏览器必须经过长时间的轮询问题而产生的,websocket 实现了多路复用,全双工通信方式,该协议可以实现客户端和浏览器端同时发送数据。

WebSocket使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。在WebSocket API中,浏览器和服务器只需要完成一次握手,两者之间就直接可以创建持久性的连接,并进行双向数据传输。

使用

在maven中引入webSocket坐标。

<!--webSocket-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-websocket</artifactId>
</dependency>

新增WebSocketConfig 配置文件类。

@Configuration
public class WebSocketConfig {
    @Bean
    public ServerEndpointExporter serverEndpointExporter() {
        System.out.println("注入ServerEndpointExporter");
        return new ServerEndpointExporter();
    }
}

后端接口到消息,进行处理。

@Slf4j
@RestController
@RequestMapping("/websocket")
public class WebSocketController {
    @GetMapping("test/{userId}")
    public void test(@PathVariable("userId") String userId) {
        try {
            SimpleDateFormat dateFormat = new SimpleDateFormat("HH:mm:ss");
            String date = dateFormat.format(new Date());
            WebSocketServer.sendInfo("后端服务推送信息:"+ date, userId);
        } catch (Exception e) {
            log.error("分页查询数据接口列表失败", e);
        }
    }
}

最后

websocket与http的关系

相同点:

  • 都是基于tcp的,都是可靠性传输协议
  • 都是应用层协议

不同点:

  • WebSocket是双向通信协议,模拟Socket协议,可以双向发送或接受信息
  • HTTP是单向的
  • WebSocket是需要浏览器和服务器握手进行建立连接的
  • 而http是浏览器发起向服务器的连接,服务器预先并不知道这个连接