SprinBoot——SpringBoot项目WebSocket推送

该博客详细介绍了如何使用WebSocket实现服务器与前端页面的实时通信。通过`onOpen`、`onClose`、`onMessage`和`onError`等方法处理连接建立、关闭、接收和发送消息的逻辑。同时,展示了当接收到客户端消息时如何群发到所有在线用户,并在前端展示消息。此外,还提供了前端页面的JavaScript代码片段,用于打开和关闭WebSocket连接以及发送消息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

webSocketSet.add(this); //加入set中

addOnlineCount(); //在线数加1

System.out.println(“有新连接加入!当前在线人数为” + getOnlineCount());

try {

sendMessage(“新人上限”);

} catch (IOException e) {

System.out.println(“IO异常”);

}

}

/**

  • 连接关闭调用的方法

*/

@OnClose

public void onClose() {

webSocketSet.remove(this); //从set中删除

subOnlineCount(); //在线数减1

System.out.println(“有一连接关闭!当前在线人数为” + getOnlineCount());

}

/**

  • 收到客户端消息后调用的方法

  • @param message 客户端发送过来的消息

*/

@OnMessage

public void onMessage(String message, Session session) {

System.out.println(“来自客户端的消息:” + message);

//群发消息

for (MyWebSocket item : webSocketSet) {

try {

item.sendMessage(message);

} catch (IOException e) {

e.printStackTrace();

}

}

}

/**

  • 发生错误时调用

*/

@OnError

public void onError(Session session, Throwable error) {

System.out.println(“发生错误”);

error.printStackTrace();

}

public void sendMessage(String message) throws IOException {

this.session.getBasicRemote().sendText(message);

}

/**

  • 群发自定义消息

*/

public static void sendInfo(String message) throws IOException {

for (MyWebSocket item : webSocketSet) {

try {

item.sendMessage(message);

} catch (IOException e) {

continue;

}

}

}

public static synchronized int getOnlineCount() {

return onlineCount;

}

public static synchronized void addOnlineCount() {

MyWebSocket.onlineCount++;

}

public static synchronized void subOnlineCount() {

MyWebSocket.onlineCount–;

}

}

[](()3.创建前端页面


js中的端口号是本人自己定义的,可以随意定义。

My WebSocket

Welcome

<button οnclick=“send()”>Send <button οnclick=“closeWebSocket()”>Close

### Spring Boot 整合 WebSocket 实现消息推送 #### 添加依赖项 为了在Spring Boot应用程序中启用WebSocket支持,需要添加`spring-boot-starter-websocket`作为项目的依赖之一。这可以通过Gradle或Maven来完成。 对于使用Groovy编写的构建脚本,在dependencies闭包内加入如下语句[^1]: ```groovy implementation 'org.springframework.boot:spring-boot-starter-web' implementation 'org.springframework.boot:spring-boot-starter-websocket' ``` 而对于XML风格的POM文件,则应包含这样的片段[^3]: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-websocket</artifactId> </dependency> ``` #### 配置WebSocket消息代理 配置类用于设置WebSocket的消息代理和其他必要的参数。通过继承`WebSocketConfigurer`接口并重写相应的方法可以自定义WebSocket的行为。此外,还可以注册一个`SockJS`端点以便于浏览器客户端连接。 #### 创建控制器处理请求 创建一个的控制器类用来接收来自前端页面发出的HTTP升级握手请求以及后续的数据帧交换。此控制器应当标注有`@Controller`注解,并且内部方法需带有`@MessageMapping`和`@SendTo`等注解以指定路径映射关系及响应目标地址[^2]。 下面是一个简单的例子展示如何发送广播通知给所有已订阅特定主题的用户: ```java @Controller public class GreetingController { @MessageMapping("/hello") @SendTo("/topic/greetings") public String greeting(String message) throws Exception { Thread.sleep(1000); // simulated delay return "Hello, " + HtmlUtils.htmlEscape(message); } } ``` 这段代码中的`greeting()`函数会在接收到发往`/app/hello`的消息时被调用;而返回的结果则会被转发至`/topic/greetings`频道上的每一个监听者那里。 #### 启动定时任务进行消息推送 如果希望定期向在线用户推送信息,可以在应用里设定计划执行的任务。借助Spring框架自带的支持——即`@Scheduled`注解配合`SchedulingConfigurer`接口实现灵活的时间调度机制,从而达到周期性触发事件的效果。 例如,每五秒一次地向名为“time”的目的地发布当前时间戳: ```java @Component public class TimePusher implements SchedulingConfigurer { private final SimpMessagingTemplate messagingTemplate; public TimePusher(SimpMessagingTemplate messagingTemplate){ this.messagingTemplate = messagingTemplate; } @Override public void configureTasks(ScheduledTaskRegistrar taskRegistrar) { taskRegistrar.addTriggerTask( () -> messagingTemplate.convertAndSend("/topic/time", new Date()), triggerContext -> { Calendar nextExecutionTime = new GregorianCalendar(); nextExecutionTime.add(Calendar.SECOND, 5); return nextExecutionTime.getTime(); }); } } ``` 以上就是利用Spring Boot整合WebSocket来进行即时通讯的一个基本流程概述。实际开发过程中可能还会涉及到更多细节调整和技术选型考量,比如安全性增强措施、性能优化策略等方面的内容[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值