在聊天室项目的功能设计中,包含了以下功能:
1. 用户注册:用户输入用户名(昵称),以及密码进行用户名的注册
2. 用户登录:用户通过用户名和密码进行登录
3. 短信验证码获取:当用户通过手机号注册或登录的时候,需要获取短信验证码
4. 手机号注册:用户输入手机号和短信验证码进行手机号的用户注册
5. 手机号登录:用户输入手机号和短信验证码进行手机号的用户登录
6. 用户信息获取:当用户登录之后,获取个人信息进行展示
7. 头像修改:设置用户头像
8. 昵称修改:设置用户昵称
9. 签名修改:设置用户签名
10. 手机号修改:修改用户的绑定手机号
11. 好友列表的获取:当用户登录成功之后,获取自己好友列表进行展示
12. 申请好友:搜索用户之后,点击申请好友,向对方发送好友申请
13. 待处理申请的获取:当用户登录成功之后,会获取离线的好友申请请求以待处理
14. 好友申请的处理:针对收到的好友申请进行同意/拒绝的处理
15. 删除好友:删除当前好友列表中的好友
16. 用户搜索:可以进行用户的搜索用于申请好友
17. 聊天会话列表的获取:每个单人/多人聊天都有一个聊天会话,在登录成功后可以
获取聊天会话,查看历史的消息以及对方的各项信息
18. 多人聊天会话的创建:单人聊天会话在对方同意好友时创建,而多人会话需要调
用该接口进行手动创建
19. 聊天成员列表的获取:多人聊天会话中,可以点击查看群成员按钮,查看群成员
信息
20. 发送聊天消息:在聊天框输入内容后点击发送,则向服务器发送消息聊天请求
21. 获取历史消息:
a. 获取最近 N 条消息:用于登录成功后,点击对方头像打开聊天框时显示最近的消息
b. 获取指定时间段内的消息:用户可以进行聊天消息的按时间搜索
22. 消息搜索:用户可以进行聊天消息的关键字搜索
23. 文件的上传
a. 单个文件的上传:这个接口基本用于后台部分,收到文件消息后将文件数据转发给文 件子服务进行存储
b. 多个文件的上传:这个接口基本用于后台部分,收到文件消息后将文件数据转发给文件子服务进行存储
24. 文件的下载
a. 单个文件的下载:在后台用于获取用户头像文件数据,以及客户端用于获取文件/语音/图片消息的文件数据
b. 多个文件的下载:在后台用于大批量获取用户头像数据(比如获取用户列表的时候),以及前端的批量文件下载
25. 语音消息的文字转换:客户端进行语音消息的文字转换。
除了以上的与客户端之间交互的功能之外,还包含一些服务器后台内部所需的功能:
1. 消息的存储:用于将文本消息进行存储起来,以便于进行消息的搜索,以及离线
消息的存储。
2. 文件的存储:用于存储用户的头像文件,以及消息中的文件/图片/语音文件数据。
3. 各项用户,好友,会话数据的存储管理
基于 C++ 实现⼀个客⼾端-服务器结构的聊天程序.
• 客⼾端: 基于 Qt 实现.
• 服务器: 基于 C++ 的分布式微服务架构 + 主流后端组件.
该项⽬在设计的时候采⽤微服务框架设计,指将⼀个⼤的业务拆分称为多个⼦业务,分别在多台不同的机器节点上提供对应的服务,由⽹关服务统⼀接收多个客⼾端的各种不同请求,然后将请求分发到不同的⼦服务节点上进⾏处理,获取响应后,再转发给客⼾端。
技术要点:
gflags:针对程序运⾏所需的运⾏参数解析/配置⽂件解析框架。
gtest:针对程序编写到⼀定阶段后,进⾏的单元测试框架。
spdlog:针对项⽬中进⾏⽇志输出的框架。
protobuf:针对项⽬中的⽹络通信数据所采⽤的序列化和反序列化框架。
brpc:项⽬中的rpc调⽤使⽤的框架。
redis:⾼性能键值存储系统,⽤于项⽬中进⾏⽤⼾登录会话信息的存储管理。
mysql:关系型数据库系统,⽤于项⽬中的业务数据的存储管理。
ODB:项⽬中mysql数据库操作的ORM框架(Object-Relational Mapping,对象关系映射)
Etcd:分布式、⾼可⽤的⼀致性键值存储系统,⽤于项⽬中实现服务注册与发现功能的框架。
cpp-httplib:⽤于搭建简单轻量HTTP服务器的框架。
websocketpp:⽤于搭建Websocket服务器的框架。
rabbitMQ:⽤于搭建消息队列服务器,⽤于项⽬中持久化消息的转发消费。
elasticsearch:⽤于搭建⽂档存储/搜索服务器,⽤于项⽬中历史消息的存储管理
语⾳云平台:采⽤百度语⾳识别技术云平台实现语⾳转⽂字功能。
短信云平台:采⽤阿⾥云短信云平台实现⼿机短信验证码通知功能。
cmake:项⽬⼯程的构建⼯具。
docker:项⽬⼯程的⼀键式部署⼯具。
服务拆分:
⼊⼝⽹关服务器:主要⽤于与客⼾端直接交互,接收客⼾端的各项请求提供服务。
⽤⼾管理⼦服务:主要⽤于管理⽤⼾的数据,以及关于⽤⼾信息的各项操作。
好友管理⼦服务:主要⽤于管理好友与聊天会话管理相关的数据与操作。
转发管理⼦服务:主要⽤于封装消息进⾏转存,然后告诉⽹关服务器⼀条消息应该发给谁。
消息存储⼦服务:主要⽤于进⾏消息元信息的存储与搜索功能。
⽂件管理⼦服务:主要⽤于管理系统中⽂件类型数据的存储,⽐如⽤⼾头像,⽂件消息等。
语⾳转换⼦服务:⽤于调⽤语⾳识别SDK,进⾏语⾳识别,将语⾳转换为⽂字。
项目完成说明:
本项目由本人独立完成。