概览

STOMP(Simple Text Oriented Messaging Protocol,简单文本定向消息协议)最初是为脚本语言(如 Ruby、Python 和 Perl)连接企业消息代理而创建的。它旨在解决一组最常用的消息传递模式的最小子集。STOMP 可以通过任何可靠的双向流网络协议使用,例如 TCP 和 WebSocket。尽管 STOMP 是一个面向文本的协议,但消息负载可以是文本或二进制。

STOMP 是一个基于帧的协议,其帧模仿 HTTP。以下列表显示了 STOMP 帧的结构

COMMAND
header1:value1
header2:value2

Body^@

客户端可以使用 SENDSUBSCRIBE 命令发送或订阅消息,同时带有一个 destination 标头,该标头描述了消息的内容以及谁应该接收它。这启用了一种简单的发布-订阅机制,您可以使用它通过代理向其他连接的客户端发送消息,或者向服务器发送消息以请求执行某些工作。

当您使用 Spring 的 STOMP 支持时,Spring WebSocket 应用充当客户端的 STOMP 代理。消息被路由到 @Controller 消息处理方法,或路由到一个简单的内存中代理,该代理跟踪订阅并将消息广播给订阅用户。您还可以配置 Spring 与专用的 STOMP 代理(例如 RabbitMQ、ActiveMQ 等)一起工作,用于实际的消息广播。在这种情况下,Spring 维护与代理的 TCP 连接,将消息中继到代理,并将来自代理的消息传递给连接的 WebSocket 客户端。因此,Spring Web 应用可以依赖于统一的基于 HTTP 的安全性、通用验证和熟悉的消息处理编程模型。

以下示例展示了客户端订阅接收股票报价,服务器可以定期发出这些报价(例如,通过一个定时任务,该任务通过 SimpMessagingTemplate 将消息发送到代理)

SUBSCRIBE
id:sub-1
destination:/topic/price.stock.*

^@

以下示例展示了客户端发送一个交易请求,服务器可以通过 @MessageMapping 方法处理该请求

SEND
destination:/queue/trade
content-type:application/json
content-length:44

{"action":"BUY","ticker":"MMM","shares",44}^@

执行后,服务器可以将交易确认消息和详细信息广播给客户端。

在 STOMP 规范中,目标的含义有意被留白。它可以是任何字符串,完全由 STOMP 服务器定义它们支持的目标的语义和语法。然而,目标通常是路径状的字符串,其中 /topic/.. 表示发布-订阅(一对多),/queue/ 表示点对点(一对一)消息交换。

STOMP 服务器可以使用 MESSAGE 命令向所有订阅者广播消息。以下示例展示了服务器向订阅客户端发送股票报价

MESSAGE
message-id:nxahklf6-1
subscription:sub-1
destination:/topic/price.stock.MMM

{"ticker":"MMM","price":129.45}^@

服务器不能发送未经请求的消息。来自服务器的所有消息都必须是对特定客户端订阅的响应,并且服务器消息的 subscription 标头必须与客户端订阅的 id 标头匹配。

前面的概述旨在提供对 STOMP 协议最基本的理解。我们建议完整查阅该协议的规范