@MassageMapping和@SendTo注解详解

@MessageMapping注解是Spring Framework中用于WebSocket消息处理的注解,它用于将特定的消息路径映射到处理器方法上。@SendTo注解指定了相应消息应该被发送到的目的地路径。

一、WebSocket配置类:
java 复制代码
@Configuration
@EnableWebSocketMessageBroker
public class WebSocketConfig implements WebSocketMessageBrokerConfigurer {

    @Override
    public void configureMessageBroker(MessageBrokerRegistry config) {
        config.enableSimpleBroker("/topic");
        config.setApplicationDestinationPrefixes("/app");
    }

    @Override
    public void registerStompEndpoints(StompEndpointRegistry registry) {
        registry.addEndpoint("/gs-guide-websocket");
    }

}
  • @EnableWebSocketMessageBroker注解:将此注释添加到@Configuration类中,以使用更高级别的消息传递子协议通过WebSocket启用代理支持的消息传递。
  • setApplicationDestinationPrefixes方法:配置注解标注的应用程序的前缀,可以配置一个或多个;
  • enableSimpleBroker方法:启用一个简单的消息代理,并配置一个或多个前缀来过滤以代理为目标的目的地(例如:前缀"/topic"的目的地)
  • addEndpoint方法:在给定的映射路径上通过WebSocket端点注册STOMP。
二、消息处理器:
java 复制代码
@Controller
public class GreetingController {


    @MessageMapping("/hello")
    @SendTo("/topic/greetings")
    public Greeting greeting(HelloMessage message) throws Exception {
        Thread.sleep(1000); // simulated delay
        return new Greeting("Hello, " + HtmlUtils.htmlEscape(message.getName()) + "!");
    }

}

@MessageMapping("/hello")注解表明,当客户端发送消息到/app/hello(注意:路径前缀/app是在配置中设置的)时,将调用greeting方法。@SendTo("/topic/greetings")注解制定了响应消息应该被发送到的目的地路径。

三、基于StampJS客户端部分代码:
js 复制代码
stompClient.onConnect = (frame) => {
    setConnected(true);
    console.log('Connected: ' + frame);
    stompClient.subscribe('/topic/greetings', (greeting) => {
        showGreeting(JSON.parse(greeting.body).content);
    });
};
function sendName() {
    stompClient.publish({
        destination: "/app/hello",
        body: JSON.stringify({'name': $("#name").val()})
    });
}

开源SDK:https://github.com/mingyang66/spring-parent

相关推荐
晓杰'20 小时前
Balatro后端进阶(1):自定义NestJS WebSocket Adapter实现消息拦截
后端·websocket·typescript·node.js·游戏开发·nestjs·wsadapter
只要微微辣1 天前
Vue3 + TS 企业级 WebSocket 封装实战:高可用、自动重连、心跳检测与业务解耦方案
网络·websocket·网络协议
我叫张小白。1 天前
劳动力招聘管理系统:全栈实战(Vue3+FastAPI+WebSocket+Dify)
websocket·vue·毕业设计·状态模式·fastapi·dify·智能体
Tirzano1 天前
webflux websocket 实现简单im聊天
网络·websocket·网络协议
sichuanwww1 天前
python中的websockets简单样例
python·websocket·asyncio·异步操作
vim怎么退出2 天前
排查 WebSocket "Invalid frame header" 的一次复盘
websocket·node.js·express
鼎道开发者联盟2 天前
让多端同步看到 OpenClaw tool 事件:两种无需大改源码的实现方案
websocket·openclaw
河阿里2 天前
WebSocket:从零开始到实战项目
网络·websocket·网络协议
晓杰'2 天前
从0到1实现 Balatro 游戏后端(2):NestJS框架搭建与项目结构设计
后端·websocket·typescript·node.js·游戏开发·项目实战·nestjs
小新同学^O^3 天前
简单学习 --> WebSocket
java·websocket·网络协议·学习