迷你论坛项目

  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 优化协议 & 加密传输
相关推荐
杨云龙UP3 小时前
小工具大体验:rlwrap加持下的Oracle/MySQL/SQL Server命令行交互
运维·服务器·数据库·sql·mysql·oracle·sqlserver
阿巴~阿巴~3 小时前
使用 C 语言连接 MySQL 客户端(重点)
服务器·数据库·sql·mysql·ubuntu
清水加冰3 小时前
【MySQL】SQL调优-如何分析SQL性能
数据库·sql·mysql
倔强的石头1063 小时前
【金仓数据库】ksql 指南(二) —— 创建与管理本地数据库
数据库·kingbasees·金仓数据库
编程充电站pro3 小时前
SQL 面试题解析:如何用多表查询写用户订单统计?
数据库·sql
小蒜学长5 小时前
jsp基于JavaWeb的原色蛋糕商城的设计与实现(代码+数据库+LW)
java·开发语言·数据库·spring boot·后端
摩羯座-1856903059414 小时前
爬坑 10 年!京东店铺全量商品接口实战开发:从分页优化、SKU 关联到数据完整性闭环
linux·网络·数据库·windows·爬虫·python
编程充电站pro15 小时前
SQL 面试高频:INNER JOIN vs LEFT JOIN 怎么考?
数据库·sql
这周也會开心15 小时前
SQL-窗口函数做题总结
数据库·sql