使用Spring Boot实现WebSocket广播

使用Spring Boot实现WebSocket广播

Spring Boot提供了对WebSocket的支持,可以方便地实现广播功能。以下是实现步骤:

  1. 添加依赖 :在pom.xml文件中添加Spring Boot WebSocket的依赖:

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-websocket</artifactId>

</dependency>

2配置WebSocket :创建一个配置类WebSocketConfig,继承AbstractWebSocketMessageBrokerConfigurer,并配置WebSocket的端点和消息代理:

@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("/websocket").withSockJS();

}

}

创建控制器 :创建一个控制器WebSocketController,用于处理客户端发送的消息并将其广播到所有订阅了相应主题的客户端:

@Controller

public class WebSocketController {

@MessageMapping("/broadcast")

@SendTo("/topic/messages")

public String broadcastMessage(@Payload String message) {

return "广播消息: " + message;

}

}

客户端代码:在前端应用中,使用JavaScript和SockJS库连接到WebSocket服务器并发送/接收消息:

JavaScript

var socket = new SockJS('/websocket');

var stompClient = Stomp.over(socket);

stompClient.connect({}, function(frame) {

console.log('Connected: ' + frame);

stompClient.subscribe('/topic/messages', function(response) {

console.log('Received message: ' + response.body);

});

stompClient.send("/app/broadcast", {}, 'Hello, WebSocket!');

});

相关推荐
皮皮林5516 小时前
SpringBoot 全局/局部双模式 Gzip 压缩实战:14MB GeoJSON 秒变 3MB
java·spring boot
weixin_456904276 小时前
Spring Boot 用户管理系统
java·spring boot·后端
奔跑吧邓邓子6 小时前
【Java实战㉞】从0到1:Spring Boot Web开发与接口设计实战
java·spring boot·实战·web开发·接口设计
茶本无香7 小时前
深入理解Spring Boot的EnvironmentPostProcessor:环境处理的黑科技
spring boot
奔跑吧邓邓子7 小时前
【Java实战㉝】Spring Boot实战:从入门到自动配置的进阶之路
java·spring boot·实战·自动配置
ONLYOFFICE7 小时前
【技术教程】如何将ONLYOFFICE文档集成到使用Spring Boot框架编写的Java Web应用程序中
java·spring boot·编辑器
cyforkk7 小时前
Spring 异常处理器:从混乱到有序,优雅处理所有异常
java·后端·spring·mvc
程序员爱钓鱼8 小时前
Go语言实战案例-开发一个Markdown转HTML工具
前端·后端·go
桦说编程8 小时前
爆赞!完全认同!《软件设计的哲学》这本书深得我心
后端