@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()})
});
}