程序聚合 软件案例 c++基于微服务的即时通讯系统

c++基于微服务的即时通讯系统

2026-01-16 14:52:52
行业:社交
载体:Windows应用
技术:C++、Qt、Docker、MySQL

业务和功能介绍

在聊天室项目的功能设计中,包含了以下功能:
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,进⾏语⾳识别,将语⾳转换为⽂字。
项目完成说明:
本项目由本人独立完成。

示例图片视频


橙子师兄
24小时内活跃
方向: 后端-C++、
交付率:100.00%
相似推荐
国泰海通融资融券后端交易系统
融资融券交易系统后台是证券公司支持客户进行信用交易(即融资买入和融券卖出)的核心业务系统,其主要目标是在控制风险的前提下,实现资金与证券的借贷、交易、清算及监控。 一、核心业务 融资交易:客户以自有资产为担保,向券商借入资金买入证券。 融券交易:客户借入券商持有的证券并卖出,未来买回归还。 二、主要功能模块(简述) 表格 模块 功能说明 信用账户管理 开立信用资金/证券账户,管理客户授信额度 担保品管理 接受现金、股票等作为担保,按规则折算价值 合约管理 记录每笔融资/融券的金额、利率、期限、标的等 盯市与风控 实时计算维持担保比例,触发预警、追保或强制平仓 强制平仓 当客户风险超标时,自动或人工执行平仓操作 清算交收 与交易所、中国结算对接,完成资金和证券的交收 计息与费用 按日计收融资利息/融券费用,生成账单 报表与监管报送 生成对账单,并向监管机构报送信用交易数据 三、关键特点 强风控驱动:所有操作围绕“维持担保比例”动态管理; 高合规要求:严格遵循证监会及交易所规则; 系统高可靠:需7×24小时稳定运行,尤其在极端行情下保障平仓能力。 简言之:融资融券后台 = 信用账户 + 借贷管理 + 实时风控 + 自动平仓 + 清算合规。
研发工作台
用于会议评审的平台,约定会议主题需参与的人员,以及中主要讨论的问题点都有哪些,每个问题点涉及到的决策与代办的任务等用于记录。模块包括:评审设置,评审会议,评审议题,评审决策,评审待办任务,任务流程,评审知识库等。
招投标平台
招投标平台这样的B端项目,服务于企业与企业之间,因此熟悉Excel、pdf、word的生成与转化,复杂的业务逻辑,以及对于sql的优化,B端项目不同于电商项目,交互与生成并不是最重要的,而是各种大数据量查询及展示
电商-mmt卡券
卡券售卖平台,业务员沟通客户,在平台上做单,产生公司利润,业务员业绩以及流水明细报表,付款收款、财务报表,是一个集成自动付款的erp系统 使用的框架机器人获取群消息,java接收,erp走付款产生业绩 利润
软件下载与分发官方网站-微简
1.Android 安装包分发 - 官网首页与下载页只聚焦 Android 版本,提供“下载 Android 版”入口。 - 支持上传新的安装包,自动更新下载列表和最新版本信息。 2.自动更新服务 - 提供最新版查询接口:客户端可拉取当前最新版本、下载链接、哈希值等。 - 提供版本列表接口:支持客户端或管理后台回溯历史版本。 3.安全与合规能力 - 登录保护:外部密码文件存储、固定管理员用户名、多因素认证扩展点。 - 会话安全:安全 Cookie、会话超时、CSRF 防护(后台操作)、登录冷却。 - WAF 与 IP 策略:黑白名单、简单攻击特征检测,降低恶意访问风险。 - 上传安全:后缀白名单 + Android 包结构校验(AndroidManifest.xml / classes.dex 等),异常结构直接拒绝。 - 下载安全:Content-Type 正确标注、ETag 与 Digest 返回,便于客户端校验完整性。 4.运维与监控 - 上传/下载操作日志记录,包含时间、IP、文件信息。 - 针对异常 MIME、大文件、结构异常包触发告警记录,便于后续排查。 5.外观与体验 - 支持深色/浅色主题切换,记住用户偏好。 - 下载按钮文案统一为“下载 Android 版”,避免多平台信息干扰。
帮助文档   Copyright @ 2021-2024 程聚宝 | 浙ICP备2021014372号
人工客服