时间:2021-05-19
一、添加依赖
加入前端需要用到的依赖:
<dependency> <groupId>org.webjars</groupId> <artifactId>sockjs-client</artifactId> <version>1.1.2</version> </dependency> <dependency> <groupId>org.webjars</groupId> <artifactId>jquery</artifactId> <version>3.4.1</version> </dependency> <dependency> <groupId>org.webjars</groupId> <artifactId>stomp-websocket</artifactId> <version>2.3.3</version> </dependency> <dependency> <groupId>org.webjars</groupId> <artifactId>webjars-locator-core</artifactId> </dependency>二、配置 WebSocketConfig
@Configuration//开启使用STOMP协议来传输基于代理的消息,Broker就是代理的意思@EnableWebSocketMessageBrokerpublic class WebSocketConfig implements WebSocketMessageBrokerConfigurer { /** * 配置消息代理 * @param registry */ @Override public void configureMessageBroker(MessageBrokerRegistry registry) { //定义消息代理的前缀 registry.enableSimpleBroker("/topic"); //配置一个或者多个前缀,过滤出需要代理方法处理的消息 registry.setApplicationDestinationPrefixes("/app"); } /** * 注册STOMP协议的节点,并指定映射的URL * @param registry */ @Override public void registerStompEndpoints(StompEndpointRegistry registry) { //注册STOMP协议节点,同时指定使用 SockJS 协议 registry.addEndpoint("/chat").withSockJS(); }}三、配置 Message 类
Message 类用来接收浏览器发送的信息
public class Message { private String name; private String content; public String getName() { return name; } public void setName(String name) { this.name = name; } public String getContent() { return content; } public void setContent(String content) { this.content = content; }}四、配置控制器 GreetingController
@Controllerpublic class GreetingController { /** * 这个方法用来处理浏览器发送来的消息,对其进行处理 * @param message * @return */ //@MessageMapping 类似 @RequestMapping @MessageMapping("/hello") //处理完之后对其进行转发到 SendTo 中的路径 @SendTo("/topic/greetings") public Message greeting(Message message) { return message; }}这里也可以使用 SimpMessagingTemplate 来进行设置:
@Controllerpublic class GreetingController { @Autowired SimpMessagingTemplate simpMessagingTemplate; @MessageMapping("/hello") public void greeting(Message message) { simpMessagingTemplate.convertAndSend("/topic/greetings", message); }}SimpMessagingTemplate这个类主要是实现向浏览器发送消息的功能。
五、设置前端页面 chat.html
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>群聊</title> <script src="/webjars/jquery/jquery.min.js"></script> <script src="/webjars/sockjs-client/sockjs.min.js"></script> <script src="/webjars/stomp-websocket/stomp.min.js"></script></head><body><table> <tr> <td>请输入用户名</td> <td><input type="text" id="name"></td> </tr> <tr> <td><input type="button" id="connect" value="连接"></td> <td><input type="button" id="disconnect" disabled="disabled" value="断开连接"></td> </tr></table><div id="chat" style="display: none"> <table> <tr> <td>请输入聊天内容</td> <td><input type="text" id="content"></td> <td><input type="button" id="send" value="发送"></td> </tr> </table> <div id="conversation">群聊进行中...</div></div><script> $(function () { $("#connect").click(function () { connect(); }) $("#disconnect").click(function () { if (stompClient != null) { stompClient.disconnect(); } setConnected(false); }) $("#send").click(function () { //将消息发送到代理方法内 stompClient.send('/app/hello',{},JSON.stringify({'name':$("#name").val(),'content':$("#content").val()})) }) }) var stompClient = null; function connect() { if (!$("#name").val()) { return; } //建立连接 var socket = new SockJS('/chat'); stompClient = Stomp.over(socket); //建立连接 stompClient.connect({}, function (success) { setConnected(true); stompClient.subscribe('/topic/greetings', function (msg) { //拿到输入的消息内容进行展示 showGreeting(JSON.parse(msg.body)); }); }) } //展示消息的内容 function showGreeting(msg) { $("#conversation").append('<div>' + msg.name + ':' + msg.content + '</div>'); } //设置连接按钮,已经连接上则禁止,反之不禁止 function setConnected(flag) { $("#connect").prop("disabled", flag); $("#disconnect").prop("disabled", !flag); //连接上,才显示聊天区的内容 if (flag) { $("#chat").show(); } else { $("#chat").hide(); } }</script></body></html>六、登录测试
打开两个浏览器,实现群聊功能:
到此这篇关于一篇文章带你使用SpringBoot基于WebSocket的在线群聊实现的文章就介绍到这了,更多相关SpringBoot WebSocket在线群聊内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
基于上一篇文章,这篇文章是关于使用coverage来实现代码覆盖的操作实例,源代码在上一篇已经给出相应链接。本篇文章字用来实现代码覆盖的源代码,整个项目的测试框
1、说明 接上一篇文章asp.netuploadify实现多附件上传功能完成后,又突然用到头像上传并在线裁剪。在网上找个众多例子都没有符合要求的,有一篇文章写
本文介绍了springboot整合JMS(ActiveMQ实现),分享给大家,也给自己留个学习笔记。一、安装ActiveMQ具体的安装步骤,请参考我的另一篇文章
上一篇文章Mybatis逆工程的使用主要是讲了mybatis-generator-core-1.3.2.jar的使用,这一篇我要介绍的是,修改jar包代码,实现
在上一篇文章:Flutter进阶—实现动画效果(三)中,实现了一个随机高度、颜色的条形。这一篇文章我们会实现多个条形,同样是随机高度、颜色。首先在bar.dar