服务器资源与消息交互 微信,天天玩微信,Spring Boot 开发私有即时通信系统了解一下...

本文介绍了如何使用SpringBoot为基础框架,配合SpringSecurity和WebSocket,构建一个点对点及群聊功能的聊天系统。通过MongoDB存储数据,详细阐述了配置过程,包括启动类设置、SpringSecurity简化配置、WebSocket配置、控制器实现点对点和群聊消息的发送,并提供了客户端JavaScript交互示例。最后展示了系统效果和测试情况。

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

1/ 概述

利用Spring Boot作为基础框架,Spring Security作为安全框架,WebSocket作为通信框架,实现点对点聊天和群聊天。

2/ 所需依赖

Spring Boot 版本 1.5.3,使用MongoDB存储数据(非必须),Maven依赖如下:

1.8

3.0.0.RELEASE

2.0.0

org.springframework.boot

spring-boot-starter-websocket

org.springframework.boot

spring-boot-starter-tomcat

org.springframework.boot

spring-boot-starter-undertow

org.springframework.boot

spring-boot-starter-security

org.springframework.boot

spring-boot-starter-data-mongodb

org.springframework.boot

spring-boot-starter-thymeleaf

org.projectlombok

lombok

1.16.16

com.alibaba

fastjson

1.2.30

org.webjars

webjars-locator

org.webjars

sockjs-client

1.0.2

org.webjars

stomp-websocket

2.3.3

org.webjars

bootstrap

3.3.7

org.webjars

jquery

3.1.0

配置文件内容:

server:

port: 80

# 若使用MongoDB则配置如下参数

spring:

data:

mongodb:

uri: mongodb://username:password@172.25.11.228:27017

authentication-database: admin

database: chat

大致程序结构,仅供参考:

eb6659a29c1641f3f4a13d40e444c1e5.png

程序结构

3/ 创建程序启动类,启用WebSocket

使用@EnableWebSocket注解

@SpringBootApplication

@EnableWebSocket

public class Application {

public static void main(String[] args) {

SpringApplication.run(Application.class, args);

}

}

4/ 配置Spring Security

此章节省略。(配置好Spring Security,用户能正常登录即可)

可以参考:Spring Boot 全栈开发:用户安全

5/ 配置Web Socket(结合第7节的JS看)

@Configuration

@EnableWebSocketMessageBroker

@Log4j

public class WebSocketConfig extends AbstractWebSocketMessageBrokerConfigurer {

// 此处可注入自己写的Service

@Override

public void registerStompEndpoints(StompEndpointRegistry stompEndpointRegistry) {

// 客户端与服务器端建立连接的点

stompEndpointRegistry.addEndpoint("/any-socket").withSockJS();

}

@Override

public void configureMessageBroker(MessageBrokerRegistry messageBrokerRegistry) {

// 配置客户端发送信息的路径的前缀

messageBrokerRegistry.setApplicationDestinationPrefixes("/app");

messageBrokerRegistry.enableSimpleBroker("/topic");

}

@Override

public void configureWebSocketTransport(final WebSocketTransportRegistration registration) {

registration.addDecoratorFactory(new WebSocketHandlerDecoratorFactory() {

@Override

public WebSocketHandler decorate(final WebSocketHandler handler) {

return new WebSocketHandlerDecorator(handler) {

@Override

public void afterConnectionEstablished(final WebSocketSession session) throws Exception {

// 客户端与服务器端建立连接后,此处记录谁上线了

String username = session.getPrincipal().getName();

log.info("online: " + username);

super.afterConnectionEstablished(session);

}

@Override

public void afterConnectionClosed(WebSocketSession session, CloseStatus closeStatus) throws Exception {

// 客户端与服务器端断开连接后,此处记录谁下线了

String username = session.getPrincipal().getName();

log.info("offline: " + username);

super.afterConnectionClosed(session, closeStatus);

}

};

}

});

super.configureWebSocketTransport(registration);

}

}

6/ 点对点消息,群消息

@Controller

@Log4j

public class ChatController {

@Autowired

private SimpMessagingTemplate template;

// 注入其它Service

// 群聊天

@MessageMapping("/notice")

public void notice(Principal principal, String message) {

// 参数说明 principal 当前登录的用户, message 客户端发送过来的内容

// principal.getName() 可获得当前用户的username

// 发送消息给订阅 "/topic/notice" 且在线的用户

template.convertAndSend("/topic/notice", message);

}

// 点对点聊天

@MessageMapping("/chat")

public void chat(Principal principal, String message){

// 参数说明 principal 当前登录的用户, message 客户端发送过来的内容(应该至少包含发送对象toUser和消息内容content)

// principal.getName() 可获得当前用户的username

// 发送消息给订阅 "/user/topic/chat" 且用户名为toUser的用户

template.convertAndSendToUser(toUser, "/topic/chat", content);

}

}

7/ 客户端与服务器端交互

var stompClient = null;

function connect() {

var socket = new SockJS('/any-socket');

stompClient = Stomp.over(socket);

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

// 订阅 /topic/notice 实现群聊

stompClient.subscribe('/topic/notice', function (message) {

showMessage(JSON.parse(message.body));

});

// 订阅 /user/topic/chat 实现点对点聊

stompClient.subscribe('/user/topic/chat', function (message) {

showMessage(JSON.parse(message.body));

});

});

}

function showMessage(message) {

// 处理消息在页面的显示

}

$(function () {

// 建立websocket连接

connect();

// 发送消息按钮事件

$("#send").click(function () {

if (target == "TO_ALL"){

// 群发消息

// 匹配后端ChatController中的 @MessageMapping("/notice")

stompClient.send("/app/notice", {}, '消息内容');

}else{

// 点对点消息,消息中必须包含对方的username

// 匹配后端ChatController中的 @MessageMapping("/chat")

var content = "{'content':'消息内容','receiver':'anoy'}";

stompClient.send("/app/chat", {}, content);

}

});

});

8/ 效果测试

登录三个用户:Anoyi、Jock、超级管理员。

群消息测试,超级管理员群发消息:

a349fc9b18794dc34554daf33b1b3eb3.png

超级管理员

adcf402a280e8dad8022b32f2a491d98.png

Anoyi

1799c46812c3bb965df5c729933f901e.png

Jock

点对点消息测试,Anoyi给Jock发送消息,只有Jock收到消息,Anoyi和超级管理员收不到消息:

924e4a86e1b7de79d6d742f9d074a15a.png

Jock

00cc165dd21cbe37988c5e133e378f7e.png

超级管理员

51f2dd5f4216c2426a006a701cada589.png

Anoyi

9/ 轻量级DEMO(完整可运行代码)

Spring Boot 开发私有即时通信系统(WebSocket)(续)

10/ 参考文献

spring-mongodb 官方文档

Spring Framework 官方文档

Spring Guide - stomp websocket

© 著作权归作者所有,转载或内容合作请联系作者

有任何问题,请留言告诉我们哈。

e363be9dfd7d92726572512967356a2f.gif

本文由博客一文多发平台 OpenWrite 发布!

本聊天系统采用客户机/服务器(C/S)地模式来设计,是一个3层地C/S结构:数据库服务器→应用程序服务器端→应用程序客户端,其分层结构如下图所示。系统采用C/S结构,可以将任务合理分配到客户机端和服务器端,从而降低了系统的通讯开销。 1. 客户层 客户层也叫应用表示层,是应用程序地客户接口部分。给聊天工具设计一个客户层具用很多优点,这是因为客户层担负着用户应用间地对话功能。它用于检查用户的输入数据,显示应用的输出数据。为了使用户能直观的进行操作,客户层需要使用接口。若聊天用户变更,系统只需改写显示控制和数据检查程序即可,而不影响其他两层。数据检查的内容限于数据的形式和值得范围,不包括有关业务的处理逻辑。 2. 服务层 服务层又叫功能层,相当于应用的本体,他是讲具体的业务出路逻辑编入程序中。例如,用户需要检索数据,系统没法将有关检索要求的信息一次性的传送给功能层:而用户登陆后,聊天登录信息是由功能层处理过的检索结果数据,他也是一次性传送给表示层的。在应用设计中,不许避免在表示层和功能层之间进行多次的数据交换,这就需要尽可能进行一次性的业务处理,达到优化整体设计的目的。 3. 数据层 数据层就是DBMS,本聊天工具使用了Microsoft公司的SQL Server2000能迅速执行大量的更新和检索,因此,从功能层传送到数据层的“要求”一般都使用SQL语言。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值