迷你论坛项目

  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 小时前
Qt SQLite在I.mx8上使用问题
数据库·qt·i.mx8
TDengine (老段)20 小时前
TDengine 转换函数 CAST 用户手册
java·大数据·数据库·物联网·时序数据库·tdengine·涛思数据
苦瓜炒蛋挞21 小时前
小迪安全第二十二天-安全开发-PHP应用&数据库操作&留言板功能&第三方插件
数据库·网络安全·php·小迪安全
chushiyunen21 小时前
redis命令 geo(对地理坐标的支持)
数据库·redis·缓存
baivfhpwxf202321 小时前
删除数据表SQL,不是删除数据,是删除表结构
数据库·sql
码界奇点1 天前
深入解析MySQL6存储过程游标与触发器的实战应用与性能优化
数据库·sql·性能优化·七牛云存储
鸽鸽程序猿1 天前
【Redis】List类型介绍
数据库·redis·list
帅中的小灰灰1 天前
C++编程观察者设计模式
数据库·c++·设计模式
2501_941664961 天前
云计算与边缘计算:新时代数字化转型的双轮驱动
数据库
x***58701 天前
GitHub星标10万+的Redis项目,使用教程
数据库·redis·github