迷你论坛项目

  1. 项目概述
    • 项目名称:基于 Qt5 的论坛客户端 & 基于 C++11/SQLite3 的服务器
    • 功能特点:注册/登录、发帖、评论、修改/删除帖子
    • 通信方式:TCP + epoll,使用自定义协议(pack.h/pack.cpp)

  1. 系统架构
    • 客户端:Qt5 + QWidget + QStackedWidget
    • 服务器:Linux C++11 + SQLite3 + epoll
    • 通信协议:自定义二进制协议(pack 封装)
    • 模块划分:
    o 客户端 UI 层(ForumWidget)
    o 网络管理层(NetworkManager)
    o 服务器通信处理(epoll + socket)
    o 数据存储层(SQLite3 数据库)

  1. 功能介绍
    • 注册 / 登录
    o 客户端输入用户名、密码
    o 发送 TYPE_REGIST / TYPE_LOGIN 请求
    o 服务器校验数据库,返回结果
    • 帖子列表
    o 获取所有用户的帖子,按时间倒序
    o 客户端通过 TYPE_POST_LIST 显示
    • 发帖
    o 用户输入标题+内容
    o 客户端发送 TYPE_POST_CREATE
    o 服务器写入 SQLite3
    • 查看帖子
    o 选择帖子 → 发送 TYPE_POST_VIEW
    o 返回帖子内容+评论列表
    • 评论
    o 输入评论 → TYPE_POST_COMMENT
    • 修改/删除帖子
    o TYPE_POST_EDIT / TYPE_POST_DELETE
    o 服务器检查用户 ID 是否匹配,允许操作

  1. 通信协议设计
    • 数据包结构:
    pack_size \| type \| back \| payload
    o pack_size:总长度
    o type:请求/响应类型
    o back:成功 / 失败标识
    o payload:变长数据 (UTF-8,前置长度)

  1. 数据库设计
    • users
    • id INTEGER PRIMARY KEY
    • username TEXT UNIQUE
    • password TEXT
    • created_at DATETIME
    • posts
    • id INTEGER PRIMARY KEY
    • user_id INTEGER
    • title TEXT
    • content TEXT
    • created_at DATETIME
    • comments
    • id INTEGER PRIMARY KEY
    • post_id INTEGER
    • user_id INTEGER
    • content TEXT
    • created_at DATETIME

  1. 客户端实现
    • UI 设计
    o ForumWidget:QStackedWidget 实现登录页 & 主页面切换
    o 帖子列表页 + 帖子详情页
    • 网络通信
    o NetworkManager:封装 QTcpSocket
    o 自动分包/组包,发送 & 解析协议
    • 交互逻辑
    o UI 点击 → 调用 NetworkManager → 服务器响应 → 更新 UI

  1. 服务器实现
    • TCP 通信
    o 使用 epoll + 非阻塞 IO
    • 请求处理
    o 根据 type 分发(登录、发帖、评论...)
    o 访问 SQLite3 进行增删改查
    • 响应
    o 打包成 pack 返回客户端

  1. 项目亮点
    • 自定义协议:相比 JSON 更轻量,传输高效
    • epoll 高并发:支持多个客户端同时访问
    • SQLite3 存储:轻量数据库,部署简单
    • Qt5 UI 美观:使用 QStackedWidget + QSS 样式

  1. 演示流程
  2. 打开客户端 → 登录
  3. 查看帖子列表
  4. 发布帖子
  5. 查看帖子详情 → 添加评论
  6. 修改/删除自己的帖子

  1. 总结与展望
    • 总结:
    o 实现了一个完整的论坛系统(客户端 + 服务器)
    o 支持多用户、发帖、评论、修改、删除
    • 展望:
    o 增加图片上传
    o 增加 Web 前端
    o 优化协议 & 加密传输
相关推荐
暴躁小师兄数据学院20 小时前
【AI大数据工程师特训笔记】第05讲:关联查询
数据库·sql·oracle
倔强的石头_20 小时前
《Kingbase护城河》——跨平台环境下的数据库联调实战
数据库
lzhdim20 小时前
SQL 入门 17:MySQL 数据类型:从字符串到 JSON 的全面解析
数据库·sql·mysql·json
杨云龙UP21 小时前
Oracle RAC / ODA 生产环境指定 PDB 启动 SOP
linux·运维·数据库·oracle
kingwebo'sZone21 小时前
在Cent上安装Mysql 8.0的遇到的问题和解决办法
数据库·mysql·adb
幽络源小助理21 小时前
最新知识付费系统网站源码 PC+H5双端 附安装教程 – 幽络源源码网
大数据·数据库
小白考证进阶中21 小时前
Oracle OCP证书报考&考试全指南
数据库·oracle·oracle ocp·ocp认证·oracle认证·甲骨文认证·oracle ocp题库
Leon-Ning Liu1 天前
【真实经验分享】 ORA-600 [qesmaGetTblSeg1]
数据库·oracle
与数据交流的路上1 天前
MySQL 优化 -- 相关
数据库·mysql
Rooting++1 天前
为什么mysql的表字段的collation会自动变
数据库·mysql