程序员社区

Spring Boot 结合 WebSocket 实现在线聊天

2017 年那会,公众号刚开始写没多久,松哥曾经在公众号上发过一个简易的 WebSocket 的系列,大概只有 5 篇左右。
大致上讲了下 WebSocket 的原理以及结合 Java 的具体用法,最后还做了一个五子棋对弈的游戏,在 GitHub 上开源了,感兴趣的小伙伴可以看下。

不过那个系列主要讲 WebSocket 的原生用法,没有谈到 Spring Boot 结合 WebSocket 的用法。在 Spring Boot 中,如果我们使用 WebSocket,可以不必使用晦涩的原生代码,可以结合很多现成的框架来更加方便的实现在线聊天。

今天我们就来看看如何在 Spring Boot 中结合 WebSocket 实现点对点在线聊天。

1.WebSocket 简介

1.1 HTTP/1.1 的升级特性

要说 WebSocket 协议,我们得先来说说 HTTP 协议的一个请求头,事实上,所有的 HTTP 客户端(浏览器、移动端等)都可以在请求头中包含 Connection:Upgrade ,这个表示客户端希望升级请求协议,那么希望升级成什么样的协议呢?我们需要在 Upgrade 头中指定一个或者多个协议的列表,当然这些协议必须兼容 HTTP/1.1 协议。服务器收到请求之后,如果接受升级请求,那么将会返回一个 101 的状态码,表示转换请求协议,同时在响应的 Upgrade 头中使用单个值,这个单个值就是请求协议列表中服务器支持的第一个协议(即请求头的 Upgrade 字段中列出来的协议列表中服务器支持的第一个协议)。

HTTP 升级最大的好处是最终使我们可以使用任意的协议,在升级握手完成之后,它就不再使用 HTTP 连接了,我们甚至可以在升级握手完成之后建立一个 Socket 连接,理论上我们可以使用 HTTP 升级在两个端点之间使用任何自己设计的协议,进而创建出各种各样的 TCP 通信,当然浏览器不会让开发者随意去这么做,而是要指定某些协议,WebSocket 应运而生!

大家来看松哥之前制作的一张图,这里详细解释了 websocket 协议升级的过程:

Spring Boot 结合 WebSocket 实现在线聊天插图

1.2 WebSocket 协议

OK,了解了 HTTP/1.1 协议的升级特性之后,我们再来详细看看整个过程是怎么样的?

一个 WebSocket 请求首先使用非正常的 HTTP 请求以特定的模式访问一个 URL ,这个 URL 有两种模式,分别是 ws 和 wss,对应 HTTP 协议中的 http 和 https,请求头中除了 Connection:Upgrade 之外还有一个 Upgrade:websocket ,它们两个将共同告诉服务器将连接升级为 WebSocket 这样一种全双工协议。

如此,在握手完成之后,文本消息或者其他二进制消息就可以同时在两个方向上进行发送,而不需要关闭和重建连接。此时的客户端和服务端关系其实是对等的,他们都可以互相向对方主动发消息。

注意

ws 和 wss 模式并不能算作 HTTP 协议的一部分,因为 HTTP 请求和请求头并不包含 URL 模式,HTTP 请求只在请求的第一行中包含相对于服务器的 URL ,在 Host 头中包含域名,而 WebSocket 中特有的 ws 和 wss 模式主要用于通知浏览器和 API 是希望使用 SSL/TLS(wss),还是希望使用不加密的方式(ws)进行连接。

1.3 WebSocket 的优势

说了这么多,那么接下来我们来看看 WebSocket 协议都有哪些优势:

  1. 由于 WebSocket 连接在端口80(ws)或者443(wss)上创建,与 HTTP 使用的端口相同,这样,基本上所有的防火墙都不会阻塞 WebSocket 连接

  2. WebSocket 使用 HTTP 协议进行握手,因此它可以自然而然的集成到网络浏览器和 HTTP 服务器中

  3. 使用该协议,当消息启动或者到达的时候,服务端和客户端都可以知道

.....

等等,还有很多。

1.4 WebSocket 的用途

凡是涉及到即时通讯的,基本上都能用上它:

  1. 网页上的在线聊天

  2. 多人在线游戏

  3. 在线股票网站

  4. 在线即时新闻网站

  5. 高清视频流

  6. 应用集群之间的通信

  7. 远程系统/软件的状态和性能的实时监控

2. 实战

介绍完基础知识之后,接下来我们就通过一个简单的例子来看看如何在 Spring Boot 中结合 WebSocket 实现在线点对点聊天。废话不多说,看视频(本视频节选自松哥自制的 Spring Boot2 系列视频教程,本集基于 Spring Boot2.1.7 录制)。

3. 结语

好了,不知道小伙伴们看这个视频有没有看懂呢?有问题欢迎留言讨论。

Spring Boot 结合 WebSocket 实现在线聊天插图1
Spring Boot 结合 WebSocket 实现在线聊天插图2


1、前后端分离开发中动态菜单的两种实现方案

2、Spring Security 前后端分离登录,非法请求直接返回 JSON

3、使用 Nginx 部署前后端分离项目,解决跨域问题

4、喜大普奔,两个开源的 Spring Boot + Vue 前后端分离项目可以在线体验了

5、Spring Boot 整合 OAuth2,松哥手把手教你!

6、一个小小的里程碑!啥也不说了,签名书奉上!

7、七个开源的 Spring Boot 前后端分离项目,一定要收藏!

8、一键部署 Spring Boot 到远程 Docker 容器,就是这么秀

9、40 篇原创干货,带你进入 Spring Boot 殿堂!

Spring Boot 结合 WebSocket 实现在线聊天插图3

喜欢就点个"在看"呗^_^

本文分享自微信公众号 - 江南一点雨(a_javaboy)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

赞(0) 打赏
未经允许不得转载:IDEA激活码 » Spring Boot 结合 WebSocket 实现在线聊天

一个分享Java & Python知识的社区