springboot整合websocket实现聊天室对话

本文详细介绍了如何使用SpringBoot和WebSocket技术构建一个简单的聊天室应用,包括添加依赖、配置WebSocket、创建消息控制器和前端页面的实现步骤。
摘要由CSDN通过智能技术生成

要实现Spring Boot整合WebSocket实现聊天室对话,你需要遵循以下步骤:

1. 添加依赖

在你的pom.xml文件中添加以下依赖:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-websocket</artifactId>
</dependency>

2. 配置WebSocket

创建一个配置类,继承AbstractWebSocketMessageBrokerConfigurer,并重写相关方法:

import org.springframework.context.annotation.Configuration;
import org.springframework.messaging.simp.config.MessageBrokerRegistry;
import org.springframework.web.socket.config.annotation.AbstractWebSocketMessageBrokerConfigurer;
import org.springframework.web.socket.config.annotation.EnableWebSocketMessageBroker;
import org.springframework.web.socket.config.annotation.StompEndpointRegistry;

@Configuration
@EnableWebSocketMessageBroker
public class WebSocketConfig extends AbstractWebSocketMessageBrokerConfigurer {

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

    @Override
    public void registerStompEndpoints(StompEndpointRegistry registry) {
        registry.addEndpoint("/chat").withSockJS();
    }
}

3. 创建消息控制器

创建一个控制器类,用于处理客户端发送的消息:

import org.springframework.messaging.handler.annotation.MessageMapping;
import org.springframework.messaging.handler.annotation.SendTo;
import org.springframework.stereotype.Controller;

@Controller
public class ChatController {

    @MessageMapping("/send")
    @SendTo("/topic/messages")
    public String handleMessage(String message) {
        return message;
    }
}

4. 前端页面

创建一个HTML页面,用于显示聊天室和发送消息的表单:

<!DOCTYPE html>
<html>
<head>
    <title>Chat Room</title>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/sockjs-client/1.5.0/sockjs.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/stomp.js/2.3.3/stomp.min.js"></script>
</head>
<body>
    <div id="chatroom">
        <ul id="messages"></ul>
    </div>
    <form id="form">
        <input type="text" id="input" placeholder="Type your message here...">
        <button type="submit">Send</button>
    </form>
    <script>
        var socket = new SockJS('/chat');
        var stompClient = Stomp.over(socket);
        var messagesElement = document.getElementById('messages');
        var formElement = document.getElementById('form');
        var inputElement = document.getElementById('input');

        stompClient.connect({}, function (frame) {
            console.log('Connected: ' + frame);
            stompClient.subscribe('/topic/messages', function (message) {
                var li = document.createElement('li');
                li.appendChild(document.createTextNode(message.body));
                messagesElement.appendChild(li);
            });
        });

        formElement.addEventListener('submit', function (event) {
            event.preventDefault();
            stompClient.send("/app/send", {}, inputElement.value);
            inputElement.value = '';
        });
    </script>
</body>
</html>

现在,你可以运行你的Spring Boot应用程序,访问http://localhost:8080,在聊天室中发送和接收消息。

  • 7
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值