迷你论坛项目

  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 优化协议 & 加密传输
相关推荐
咖啡の猫11 小时前
Python字典的查询操作
数据库·python·c#
这儿有一堆花11 小时前
2025 年免费指纹浏览器清单
数据库
czhc114007566312 小时前
c# 1213
开发语言·数据库·c#
voltina12 小时前
【SQL】【事务】
数据库·sql
古渡蓝按13 小时前
PostgreSQL数据库在Windows上实现异地自动备份指南-喂饭图文教程
数据库
她说..13 小时前
MySQL数据处理(增删改)
java·开发语言·数据库·mysql·java-ee
E***U94513 小时前
从新手到入门:如何判断自己是否真的学会了 Spring Boot
数据库·spring boot·后端
Alex Gram13 小时前
MySQL实时同步到SQL Server:技术方案与实现路径
数据库·mysql
不穿格子的程序员13 小时前
Redis篇3——Redis深度剖析:内存数据的“不死之身”——RDB、AOF与混合持久化
数据库·redis·缓存·数据持久化·aof·rdb
秋深枫叶红13 小时前
嵌入式第三十四篇——linux系统编程——进程
linux·服务器·数据库·学习