迷你论坛项目

  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 优化协议 & 加密传输
相关推荐
ClouGence11 小时前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
飞将13 小时前
从零实现数据库(2)——HashIndex + IndexManager
数据库
Nturmoils1 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波2 天前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
倔强的石头_3 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
倔强的石头_5 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab6 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence6 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神7 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据7 天前
数据服务化时代:企业数据能力输出的核心路径
数据库