一、实验题目
灌水论坛系统
二、实验目的
旨在通过一个相对完整且功能丰富的Web应用实例,全面地实践和巩固Web开发所需的各项核心技术和工程方法,从而提升其综合应用能力和解决实际开发问题的能力。它不仅仅是完成一个软件,更是一个学习、实践和提升的过程
灵感:想要设计一个类似于 CSDN 的博客论坛,可以在里面分享自己的知识、感受,大家也可以在里面交流
三、总体设计(含背景知识或基本原理与算法、或模块介绍、设计步骤等)
1. 项目背景与需求分析
灌水论坛系统是一个基于Java Web技术的现代化网络论坛平台,旨在为用户提供一个分享知识、交流经验、发布内容的在线社区。该系统以轻量级论坛为设计目标,注重用户体验和系统性能。
1.1 核心需求
- 用户管理:支持用户注册、登录、信息修改、密码变更等基本功能
- 内容管理:支持用户发布帖子、回复、点赞、阅读统计等功能
- 版块管理:支持多个专业分类版块,便于用户按兴趣浏览内容
- 交互功能:提供用户间的私信交流功能
- 搜索功能:提供帖子和用户的快速检索功能
1.2 用户角色
- 普通用户:注册用户,可以浏览、发帖、回复、点赞
- 管理员:拥有内容管理权限,可以维护论坛秩序
1.3 相关技术及工具
服务器端技术:Spring、Spring Boot、Spring MVC、MyBatis
浏览器端技术:HTML、CSS、JavaScript、jQuery、Bootstrap
数据库:MySQL
项目构建工具:Maven
版本控制工具:Git + GITEE
2. 系统架构设计
2.1 总体架构
系统采用经典的三层架构模式,实现了前后端的逻辑分离:
-
表示层(前端):
- 基于HTML、CSS、JavaScript构建用户界面
- 使用Tabler UI框架提供现代化的界面组件
- 采用AJAX技术实现异步数据交互
-
业务逻辑层(后端):
- 基于Spring Boot框架实现RESTful API
- 使用MVC设计模式组织代码结构
- 通过Service层封装业务逻辑
-
数据访问层:
- 使用MyBatis作为ORM框架
- 设计规范化的MySQL数据库结构
- 实现高效的数据访问和操作
2.2 技术架构
客户端层:HTML + CSS + JavaScript + Tabler UI|| HTTP/HTTPSv
应用服务层:Spring Boot + Spring MVC + Swagger|| MyBatisv
数据存储层:MySQL数据库
3. 数据库设计
系统采用MySQL数据库,设计了规范化的数据表结构:
3.1 核心表设计
公共字段:无特殊要求的情况下,每张表必须有长整型的自增主键,删除状态、创建时间、更新时间,如下所示:
字段 | 类型 | 非空(Y/N) | 主键(Y/N) | 默认值 | 备注 |
---|---|---|---|---|---|
id | bigint | Y | Y | 编号,主键自增 | |
state | tinyint | Y | N | 0 | 状态,0正常,1禁用 |
deletState | tinyint | Y | N | 0 | 是否删除,0否,1是 |
creatTime | dateTime | Y | N | 创建时间,精确到 s | |
updateTime | dateTime | Y | N | 更新时间,精确到 s |
(1)用户表 (t_user):
- 存储用户基本信息,包括账号、密码、个人资料
- 采用盐值加密技术保护用户密码安全
- 字段设计:id、username、password、nickname、phoneNum、email、gender、salt、avatarUrl、articleCount、isAdmin、remark、state、deleteState、createTime、updateTime
字段 | 类型 | 非空(Y/N) | 主键(Y/N) | 默认值 | 备注 |
---|---|---|---|---|---|
id | bigint | Y | Y | 编号, 主键自增 | |
username | varchar(20) | Y | N | 用户名, 唯一 | |
password | varchar(32) | Y | N | 加密后密码 | |
nickname | varchar(50) | Y | N | 昵称 | |
phoneNum | varchar(20) | N | N | NULL | 手机号 |
varchar(50) | N | N | NULL | 电子邮箱 | |
gender | tinyint | Y | N | 2 | 性别: 0女, 1男, 2保密 |
salt | varchar(32) | Y | N | 密码加密 | |
avatarUrl | varchar(255) | N | N | NULL | 用户头像路径 |
articleCount | int | Y | N | 0 | 发帖数量 |
isAdmin | tinyint | Y | N | 0 | 是否管理员: 0否, 1是 |
remark | varchar(1000) | N | N | NULL | 备注, 自我介绍 |
state | tinyint | Y | N | 0 | 状态: 0正常, 1禁言 |
deleteState | tinyint | Y | N | 0 | 是否删除: 0否, 1是 |
createTime | datetime | Y | N | 创建时间, 精确到秒 | |
updateTime | datetime | Y | N | 更新时间, 精确到秒 |
注意:这里存图片我们用的是路径,而不是直接存图片本身,这样大大减少服务器占用空间(用图床存图片,然后从图床提出图片即可)
(2)版块表 (t_board):
- 管理论坛的分类板块信息
- 字段设计:id、name、articleCount、sort、state、deleteState、createTime、updateTime
字段 字段 | 类型 | 非空(Y/N) | 主键(Y/N) | 默认值 | 备注 备注 |
---|---|---|---|---|---|
id | bigint | Y | Y | 编号, 主键自增 | |
name | varchar(50) | Y | N | 版块名 | |
articleCount | int | Y | N | 0 | 帖子数量 |
sort | int | Y | N | 0 | 排序优先级, 升序 |
state | tinyint | Y | N | 0 | 状态: 0正常, 1禁用 |
deleteState | tinyint | Y | N | 0 | 是否删除: 0否, 1是 |
createTime | datetime | Y | N | 创建时间, 精确到秒 | |
updateTime | datetime | Y | N | 更新时间, 精确到秒 |
(3)帖子表 (t_article):
- 存储用户发布的帖子内容
- 记录帖子的访问量、回复数、点赞数等统计信息
- 字段设计:id、boardId、userId、title、content、visitCount、replyCount、likeCount、state、deleteState、createTime、updateTime
字段 | 类型 | 非空(Y/N) | 主键(Y/N) | 默认值 | 备注 |
---|---|---|---|---|---|
id | bigint | Y | Y | 编号,主键自增 | |
boardId | bigint | Y | N | 编号, 主键自增 (应为版块编号) | |
userId | bigint | Y | N | 发帖人, 关联用户编号 | |
title | varchar(100) | Y | N | 帖子标题 | |
content | text | Y | N | 帖子正文 | |
visitCount | int | Y | N | 0 | 访问量 |
replyCount | int | Y | N | 0 | 回复数 |
likeCount | int | Y | N | 0 | 点赞数 |
state | tinyint | Y | N | 0 | 状态: 0正常, 1禁用 |
deleteState | tinyint | Y | N | 0 | 是否删除: 0否, 1是 |
createTime | datetime | Y | N | 创建时间, 精确到秒 | |
updateTime | datetime | Y | N | 更新时间, 精确到秒 |
(4)帖子回复表 (t_article_reply):
- 存储用户对帖子的回复内容
- 支持楼中楼回复功能
- 字段设计:id、articleId、postUserId、replyId、replyUserId、content、likeCount、state、deleteState、createTime、updateTime
字段 | 类型 | 非空(Y/N) | 主键(Y/N) | 默认值 | 备注 |
---|---|---|---|---|---|
id | bigint | Y | Y | 编号, 主键自增 | |
articleId | bigint | Y | N | 关联帖子编号 | |
postUserId | bigint | Y | N | 楼主用户, 关联用户编号 | |
replyId | bigint(20) | N | N | NULL | 关联回复编号, 支持楼中楼 |
replyUserId | bigint(20) | N | N | NULL | 楼主下的回复用户编号, 支持楼中楼 |
content | varchar(500) | Y | N | 回贴内容 | |
likeCount | int | Y | N | 回贴内容 (应为点赞数) | |
state | tinyint | Y | N | 0 | 状态: 0正常, 1禁用 |
deleteState | tinyint | Y | N | 0 | 是否删除: 0否, 1是 |
createTime | datetime | Y | N | 创建时间, 精确到秒 | |
updateTime | datetime | Y | N | 更新时间, 精确到秒 |
(5)站内信表 (t_message):
- 管理用户间的私信内容
- 字段设计:id、postUserId、receiveUserId、content、state、deleteState、createTime、updateTime
字段 | 类型 | 非空(Y/N) | 主键(Y/N) | 默认值 | 备注 |
---|---|---|---|---|---|
id | bigint | Y | Y | 编号, 主键自增 | |
postUserId | bigint | Y | N | 发送者, 关联用户编号 | |
receiveUserId | bigint | Y | N | 接收者, 关联用户编号 | |
content | varchar(255) | Y | N | 内容 | |
state | tinyint | Y | N | 0 | 状态: 0正常, 1禁用 |
deleteState | tinyint | Y | N | 0 | 是否删除: 0否, 1是 |
createTime | datetime | Y | N | 创建时间, 精确到秒 | |
updateTime | datetime | Y | N | 更新时间, 精确到秒 |
3.2 数据关系
- 用户与帖子:一对多关系,一个用户可以发布多个帖子
- 版块与帖子:一对多关系,一个版块可以包含多个帖子
- 帖子与回复:一对多关系,一个帖子可以有多个回复
- 回复与回复:自引用关系,实现楼中楼回复功能
- 用户与私信:多对多关系,通过postUserId和receiveUserId建立联系
3.3 数据优化设计
- 使用软删除机制,通过deleteState字段标记删除状态,避免物理删除带来的数据丢失风险
- 在高频查询字段上建立索引,提高查询效率
- 使用createTime和updateTime记录数据的生命周期
4. 模块设计与功能实现
4.1 用户模块
用户模块负责用户账号生命周期管理,核心功能包括:
- 用户注册:
- 实现:通过UserController的register方法处理用户注册请求
- 安全措施:使用MD5+Salt方式加密存储密码
- 数据校验:实现用户名唯一性校验,密码复杂度检查
- 用户登录:
- 实现:通过UserController的login方法处理用户登录请求
- 会话管理:成功登录后将用户信息存入Session
- 安全控制:限制登录失败次数,防止暴力破解
- 个人信息管理:
- 实现:通过UserController的modifyInfo方法处理个人信息更新
- 功能:支持修改昵称、头像、个人简介等信息
- 密码管理:
- 实现:通过UserController的modifyPassword方法处理密码修改
- 安全措施:验证原密码,确保新密码符合复杂度要求
4.2 内容模块
内容模块负责论坛核心内容的发布和管理,主要功能包括:
-
帖子发布:
- 实现:通过ArticleController的createArticle方法处理帖子创建请求
- 功能:支持富文本编辑,内容格式化存储
-
帖子列表:
- 实现:通过ArticleController的getArticleList方法获取帖子列表
- 分页机制:支持分页查询,减轻服务器负担
- 排序机制:支持按最新、最热等多种方式排序
-
帖子详情:
- 实现:通过ArticleController的getArticleDetail方法获取帖子详情
- 阅读统计:自动增加帖子访问计数
- 关联数据:同时加载帖子回复信息
-
回复管理:
- 实现:通过ArticleReplyController管理回复相关功能
- 支持楼层回复和楼中楼回复两种模式
4.3 版块模块
版块模块负责论坛分类管理,主要功能包括:
-
版块列表:
- 实现:通过BoardController的getBoardList方法获取版块列表
- 排序机制:根据sort字段确定版块显示顺序
-
版块内容:
- 实现:结合ArticleController,获取特定版块下的帖子列表
- 统计信息:展示版块活跃度、帖子数量等信息
4.4 消息模块
消息模块提供用户间的私信功能,主要实现包括:
-
消息发送:
- 实现:通过MessageController的sendMessage方法处理消息发送请求
- 安全控制:限制发送频率,防止骚扰
-
消息列表:
- 实现:通过MessageController的getMessageList方法获取消息列表
- 分组展示:区分已读和未读消息
4.5 搜索模块
搜索模块提供内容检索功能,实现在帖子和用户中快速查找:
-
帖子搜索:
- 实现:通过ArticleController的searchArticles方法处理搜索请求
- 支持按标题、内容、作者等多维度搜索
-
用户搜索:
- 实现:通过UserController提供用户检索功能
- 搜索优化:采用模糊匹配和排序机制提高搜索体验
5. 技术实现与关键算法
5.1 安全认证机制
系统采用基于Session的认证机制,实现流程如下:
- 用户提交用户名和密码
- 服务器验证凭据:
- 获取用户盐值(salt)
- 使用MD5算法结合盐值计算密码哈希值
- 与数据库存储的密码哈希值比对
- 验证成功后,将用户信息存储在Session中
- 后续请求通过拦截器验证Session中是否存在有效用户信息
5.2 密码加密算法
系统使用MD5+Salt的方式存储密码,具体实现:
- 注册时生成随机32位盐值(UUID生成)
- 将密码明文与盐值拼接后进行MD5哈希
- 存储哈希结果和盐值到数据库
- 登录时重复上述哈希过程并比对结果
5.3 分页算法
系统采用物理分页方式,在SQL层面实现数据分页,减轻服务器内存压力:
- 接收页码(pageNum)和每页大小(pageSize)
- 计算偏移量 offset = (pageNum - 1) * pageSize
- 使用MyBatis分页插件或原生SQL的LIMIT子句实现数据库分页查询
- 同时查询总记录数,用于前端分页控件展示
6. 前端设计与实现
6.1 整体界面设计
前端采用Tabler UI框架,实现现代化、响应式的界面设计:
-
布局结构:
- 顶部导航栏:包含logo、搜索框、用户头像等元素
- 版块导航:显示所有论坛版块
- 内容区域:根据不同页面展示不同内容
- 侧边栏:展示热门内容、统计信息等
-
响应式设计:
- 使用Bootstrap栅格系统适配不同屏幕尺寸
- 移动端优化,确保在手机上有良好体验
6.2 核心页面
系统包含多个核心页面,各自负责不同功能:
-
首页(index.html):
- 展示版块列表和热门帖子
- 实现快速导航和搜索功能
-
帖子详情页(details.html):
- 展示帖子完整内容和回复列表
- 提供回复、点赞等交互功能
-
个人中心(profile.html、settings.html):
- 展示用户个人信息和帖子统计
- 提供个人信息编辑功能
-
发帖页(article_edit.html):
- 集成富文本编辑器
- 提供帖子编辑和预览功能
7. 系统扩展性与维护性设计
7.1 扩展性设计
系统在设计时考虑了后续功能扩展需求:
-
模块化设计:
- 遵循高内聚低耦合原则
- 各功能模块相对独立,便于扩展
-
接口设计:
- 使用RESTful API设计风格
- 通过Swagger提供API文档,便于前后端协作
-
配置外部化:
- 关键配置项通过application.yml集中管理
- 可根据不同环境切换配置
7.2 维护性设计
-
日志系统:
- 集成日志框架,记录系统运行状态
- 不同级别的日志分类存储,便于问题排查
-
异常处理:
- 全局异常处理机制,统一异常响应格式
- 详细的错误信息记录,便于定位问题
-
代码规范:
- 采用统一的命名规范和代码风格
- 适当的注释和文档,提高代码可读性
四、详细设计(含主要的数据结构、程序流程图、关键代码等)
1. 核心数据结构 (Java Model Classes)及代码
这些数据结构是项目中核心实体的 Java 对象表示,主要通过 Lombok 的 @Data
注解自动生成 getter
, setter
, toString
等方法,并使用 Swagger 注解提供 API 文档信息。
1.1 User (用户信息)
描述:存储用户的基本信息、认证信息和状态。
public class User {private Long id;@ApiModelProperty("用户名")private String username;@JsonIgnore // 不参与JSON序列化private String password;@ApiModelProperty("昵称")private String nickname;// ... 其他字段 ...@ApiModelProperty("头像地址")@JsonInclude(JsonInclude.Include.ALWAYS) // 强制参与JSON序列化private String avatarUrl;// ... 其他字段 ...@ApiModelProperty("注册日期")private Date createTime;private Date updateTime;
}
1.2 Article(帖子信息)
@Data
@ApiModel("用户信息")
public class User {private Long id; // 用户ID@ApiModelProperty("用户名")private String username; // 登录用户名@JsonIgnore // JSON序列化时忽略密码private String password; // 加密后的密码@ApiModelProperty("昵称")private String nickname; // 显示昵称@ApiModelProperty("电话号码")private String phoneNum; // 电话号码@ApiModelProperty("邮箱")private String email; // 电子邮箱@ApiModelProperty("性别")private Byte gender; // 性别(0女,1男,2保密)@JsonIgnoreprivate String salt; // 密码加密盐值@ApiModelProperty("头像地址")private String avatarUrl; // 头像URL@ApiModelProperty("发帖数量")private Integer articleCount; // 发帖数@ApiModelProperty("是否管理员")private Byte isAdmin; // 管理员标识@ApiModelProperty("个人简介")private String remark; // 个人简介private Byte state; // 用户状态private Date createTime; // 注册时间private Date updateTime; // 更新时间
}
1.3 ArticleReply (回复信息)
@Data
public class ArticleReply {private Long id; // 回复IDprivate Long articleId; // 关联帖子IDprivate Long postUserId; // 回复者IDprivate Long replyId; // 被回复的回复ID(楼中楼)private Long replyUserId; // 被回复者IDprivate String content; // 回复内容private Integer likeCount; // 点赞数private Byte state; // 回复状态private Date createTime; // 回复时间private Date updateTime; // 更新时间private User user; // 关联的用户信息
}
2. 核心功能实现
2.1 用户认证模块
(1)密码加密实现
public class MD5Util {// 使用MD5+盐值加密public static String md5Salt(String password, String salt) {String passwordSalt = password + salt;return DigestUtils.md5DigestAsHex(passwordSalt.getBytes());}
}
(2)用户登录实现
@Service
public class UserServiceImpl implements IUserService {@Resourceprivate UserMapper userMapper;@Overridepublic User login(String username, String password) {// 1. 根据用户名查询用户User user = userMapper.selectByUsername(username);if (user == null) {return null;}// 2. 验证密码String encryptPassword = MD5Util.md5Salt(password, user.getSalt());if (!encryptPassword.equals(user.getPassword())) {return null;}// 3. 清除敏感信息user.setPassword(null);user.setSalt(null);return user;}
}
2.2 帖子管理模块
(1)发帖实现
@Service
public class ArticleServiceImpl implements IArticleService {@Resourceprivate ArticleMapper articleMapper;@Resourceprivate BoardMapper boardMapper;@Override@Transactionalpublic void createArticle(Article article) {// 1. 设置初始值article.setVisitCount(0);article.setReplyCount(0);article.setLikeCount(0);article.setState((byte)0);article.setCreateTime(new Date());article.setUpdateTime(new Date());// 2. 保存帖子articleMapper.insert(article);// 3. 更新版块帖子数boardMapper.incrementArticleCount(article.getBoardId());}
}
(2)帖子列表查询
@Service
public class ArticleServiceImpl implements IArticleService {@Overridepublic PageInfo<Article> getArticleList(Integer pageNum, Integer pageSize, Long boardId) {// 1. 设置分页PageHelper.startPage(pageNum, pageSize);// 2. 查询条件ArticleExample example = new ArticleExample();if (boardId != null) {example.createCriteria().andBoardIdEqualTo(boardId).andStateEqualTo((byte)0);}example.setOrderByClause("create_time desc");// 3. 执行查询List<Article> articles = articleMapper.selectByExample(example);// 4. 填充用户信息for (Article article : articles) {User user = userMapper.selectByPrimaryKey(article.getUserId());article.setUser(user);}return new PageInfo<>(articles);}
}
2.3 回复管理模块
楼中楼回复实现
@Service
public class ArticleReplyServiceImpl implements IArticleReplyService {@Override@Transactionalpublic void reply(ArticleReply reply) {// 1. 设置初始值reply.setLikeCount(0);reply.setState((byte)0);reply.setCreateTime(new Date());reply.setUpdateTime(new Date());// 2. 保存回复replyMapper.insert(reply);// 3. 更新帖子回复数Article article = articleMapper.selectByPrimaryKey(reply.getArticleId());article.setReplyCount(article.getReplyCount() + 1);articleMapper.updateByPrimaryKey(article);}
}
3. 关键功能设计
(1)分页查询实现
使用 PageHelper 实现物理分页:
// 配置分页插件
@Configuration
public class MybatisConfig {@Beanpublic PageInterceptor pageInterceptor() {return new PageInterceptor();}
}// 使用分页
public PageInfo<Article> getArticleList(int pageNum, int pageSize) {PageHelper.startPage(pageNum, pageSize);List<Article> list = articleMapper.selectByExample(new ArticleExample());return new PageInfo<>(list);
}
(2)统一响应处理
@Data
public class AppResult<T> {private Integer code; // 状态码private String message; // 提示信息private T data; // 响应数据public static <T> AppResult<T> success(T data) {AppResult<T> result = new AppResult<>();result.setCode(0);result.setMessage("success");result.setData(data);return result;}public static AppResult failed(ResultCode resultCode) {AppResult result = new AppResult();result.setCode(resultCode.getCode());result.setMessage(resultCode.getMessage());return result;}
}
(3)安全控制实现
@Component
public class LoginInterceptor implements HandlerInterceptor {@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {// 1. 获取sessionHttpSession session = request.getSession(false);if (session == null) {response.sendRedirect("/sign-in.html");return false;}// 2. 验证用户登录状态User user = (User) session.getAttribute(AppConfig.USER_SESSION);if (user == null) {response.sendRedirect("/sign-in.html");return false;}return true;}
}
(4)文件上传实现
@RestController
@RequestMapping("/upload")
public class UploadController {@PostMapping("/image")public AppResult<String> uploadImage(@RequestParam("file") MultipartFile file) {// 1. 验证文件类型String contentType = file.getContentType();if (!contentType.startsWith("image/")) {return AppResult.failed(ResultCode.FAILED_UPLOAD_TYPE);}// 2. 生成文件名String fileName = UUID.randomUUID().toString() + file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf("."));// 3. 保存文件try {String filePath = uploadPath + fileName;file.transferTo(new File(filePath));return AppResult.success("/uploads/" + fileName);} catch (IOException e) {return AppResult.failed(ResultCode.FAILED_UPLOAD);}}
}
4. 核心流程图
(1)总体流程图
(2)注册顺序图
(3)登录顺序图
五、实验结果和分析
1. 功能模块测试结果
对系统的核心功能模块,包括用户管理、帖子管理、版块管理、回复管理、站内信以及搜索功能,进行了全面的测试。
1.1 用户注册与登录模块
(1)测试目的:验证用户能否成功注册新账户,并使用已注册账户正常登录和注销
(2)测试过程:
- 尝试使用合法的、边界的(如最短/最长用户名、密码)以及非法的(如已存在的用户名、格式错误的邮箱)数据进行用户注册
- 使用已注册的账户信息进行登录,包括正确的用户名/密码组合及错误的组合
- 验证登录后的会话保持机制以及注销功能的有效性
(3)测试结果:
① 用户注册功能:对于合法数据,用户均能成功注册;对于已存在的用户名或不符合格式要求的数据,系统能给出正确的错误提示。密码加密存储机制(MD5+Salt)按预期工作
错误提示如下:
成功注册 就直接跳转到登录页面
② 用户登录功能:使用正确的凭据可以成功登录,错误的凭据会导致登录失败并给出提示。会话在用户登录期间保持有效,注销功能可以正确清除会话。
登录失败如下:
1.2 帖子管理模块
(1)测试目的:验证用户发帖、编辑帖子、删除帖子、查看帖子列表及详情的功能
(2)测试过程:
- 测试用户在不同版块发布新帖,包括包含文本、特殊字符等内容的帖子。
- 测试帖子作者对已发布帖子的编辑和删除权限。
- 测试不同用户(包括游客、普通用户、作者)查看帖子列表和帖子详情的权限和显示内容。
- 验证帖子浏览量计数器的准确性。
(3)测试结果:
- 用户可以成功发布帖子,帖子内容能够正确显示。富文本编辑器的基本功能(如格式化)正常
- 帖子作者可以对自己发布的帖子进行编辑和删除,非作者无此权限。
- 帖子列表按预期展示,帖子详情页面能正确加载帖子内容及相关信息(如作者、发布时间)。浏览量在每次有效访问后递增。
1.3 回复管理模块
(1)测试目的:验证用户对帖子进行回复、查看回复、删除回复功能
(2)测试过程:
- 用户对帖子进行一级回复。
- 用户对已有的回复进行回复
- 回复者或管理员删除回复
- 验证回复数量统计的准确性
(3)测试结果:
- 用户可以成功对帖子进行回复,回复内容按时间顺序正确显示在帖子下方。
- 楼中楼回复功能按设计实现,能够清晰展示回复层级。
- 回复的删除权限控制有效,回复数量统计在增删操作后能正确更新。
1.4 版块管理模块
(1)测试目的:验证版块列表的展示及用户能否根据版块筛选帖子。
(2)测试过程:
- 查看首页及专门的版块导航区域是否正确显示所有已配置的版块。
- 点击不同版块,验证是否能正确筛选并展示该版块下的帖子列表。
(3)测试结果:
- 版块列表按预设的排序和名称正确展示。
- 用户可以方便地通过点击版块名称进入特定版块的帖子列表页面。
1.5 站内信模块
(1)测试目的:验证用户之间发送和接收私信的功能。
(2)测试过程:
- 用户A向用户B发送私信。
- 用户B查看收到的私信列表及具体内容。
- 验证新消息提醒机制(如小红点)。
(3)测试结果:
- 用户可以成功发送和接收站内信,消息内容准确无误。
- 新消息提醒功能及时有效。
1.6 搜索模块
(1)测试目的:验证用户能否根据关键词搜索帖子和用户
(2)测试过程:
- 输入不同关键词(存在的、部分匹配的、不存在的)搜索帖子标题和内容
- 输入不同关键词搜索用户名或昵称
(3)测试结果:
- 帖子搜索功能能够根据关键词从标题和内容中检索相关帖子,并展示结果列表
- 用户搜索功能能够根据关键词检索匹配的用户
- 对于无结果的搜索,系统能给出相应提示
1.7 身份模块
(1)测试目的:验证管理员和普通用户身份的区别
(2)测试过程:
- 管理员权限下的操作
- 普通用户权限下的操作
(3)测试结果:
- 管理员用户可以对版块、用户进行管理
- 可以对用户进行禁言或者解禁
2. 性能评估
对系统的关键操作进行了初步的性能评估,主要关注响应时间和并发处理能力。
页面加载速度
- 测试方法:使用浏览器开发者工具或第三方测速工具,在模拟不同网络环境下测试主要页面(首页、帖子列表页、帖子详情页)的加载时间
- 测试结果:
- 在普通网络环境下(如 50Mbps 带宽),主要页面的平均加载时间在 6 秒内(用户填写具体数值)
- 图片等静态资源加载速度良好,未发现明显瓶颈
六、小结和心得体会
结论:当前灌水论坛系统是一个完整的Web论坛应用,采用主流的Java技术栈,结合现代化的设计理念,实现了用户注册、登录、发帖、回复、私信等核心功能。系统架构清晰,代码组织规范,具有良好的可扩展性和维护性。
待改进之处与未来展望:
- 性能优化:针对高并发场景和大数据量进行更深入的性能测试和优化,如引入Redis缓存热点数据,优化数据库查询。
- 前端体验:进一步提升移动端适配和用户体验,考虑引入前端MVVM框架(如Vue.js)进行部分模块重构或新功能开发。
- 安全性增强:全面实施CSRF防护,加强文件上传安全校验,定期进行安全审计。
- 功能扩展:
- 引入更丰富的用户交互功能,如@提及、消息通知中心、用户等级与积分系统。
- 开发后台管理系统,方便管理员对用户、帖子、版块等进行更精细化的管理。
- 增加内容推荐算法,提升用户粘性。
至于代码的话:可以查看我的仓库