tzxblog博客系统-概要设计

2024-04-28 06:58

本文主要是介绍tzxblog博客系统-概要设计,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

v1.0

系统概述

tzxblog博客系统旨在创建一个可持续迭代的,以博客系统为基础并辅以文件下载、论坛讨论、商城等功能为一体的综合性站点。

重在持续性迭代,巩固工作中主流技术的同时,练习工作中未使用但主流或者不可或缺的技术。


整体架构

系统整体采用前后台分离思想,后台以springboot为基础框架,前台以vue为基础技术,辅以redis缓存、mysql存储、nginx转发以及ssl通信,力求软件生命周期内涉及开发的内容均可得到提现。
在这里插入图片描述


版本控制

代码版本

前后台代码均托管github,以不同分支管理大的版本,遵循如下要求:

master:最新可运行版本,从develop合并;
develop: 最新开发版本,可能不能运行,主要作用是代码备份,防止本地最新文件丢失;
realese-X.X: X.X为数字泛指,如1.0、1.1、2.0,作为稳定大功能的发布版本,由master拉出;
tags:tag版本作为废弃不用的版本存档。

文档版本

项目周期内各种文档,尽量以两种方式呈现,分别是博客文章和docx文档,类似接口文档、数据库这种不太好博客展示的,就仅以附件文档的格式输出。

其中docx文档存放于项目doc目录下,和代码一起托管于github,同时docx文档每次修改变更均要变更版本号并标注具体变更说明。


数据库设计

详见doc中数据库设计和sql脚本,后续补充。


缓存设计

为提高系统性能,使用频率高的数据需要存放于redis缓存中。


安全设计

对于接口层面,前后台接口需要有签名校验,防止网络攻击。

对于如密码这种敏感数据,传输和存储均应加密处理。

系统前期可使用http协议,功能稳定后采用自签名证书和https交互。


功能设计

首页
  1. 用户访问首页,前台向后台页面发起首页需要的各种请求:分类列表、文章列表、推荐列表,列表条数和推荐列表条数均可配置,默认分别为10和5;
  2. 后台收到请求后查询redis缓存或者mysql数据库,组装数据响应前台;
  3. 前台展示首页相关内容;
  4. 成功进入首页后,分类列表、文章列表、推荐列表、导航按钮均可进行点击后进入具体的文章页、功能页。
文章详情
  1. 用户点击文章列表、推荐列表具体文章,前台根据文章id向后台发起文章详情查询;
  2. 后台收到请求后查询redis或者mysql,组装数据后响应前台;
  3. 文章详情包含文章内容和阅读量、评论数、评论列表分页;
  4. 文章详情页面三栏布局,顶部导航,下左方用户信息,下右方文章详情。
用户基础信息
  1. 文章详情左侧显示用户基本信息,用户头像、昵称、简介、签名、以及用户文章分类和归档等信息;
  2. 点击用户头像或昵称均可进入用户个人首页。
个人首页
  1. 个人首页整体布局和文章详情类似,把文章详情区域的内容替换为文章列表。
文章评论
  1. 文章详情末尾展示评论框,可输入文字评论;
  2. 评论框下方展示评论列表,评论列表条数可配置,默认展示5条,评论必须登录。
分类查询
  1. 个人首页或首页点击分类列表中的具体分类,前台向后台发起分类文章查询;
  2. 后台查询具体分类的文章分页列表后,返回前台;
  3. 前台在个人首页的下右方主区域或者首页的下中区展示存档文章列表。
存档查询
  1. 个人首页点击存档列表中的具体月份,前台向后台发起存档文章查询;
  2. 后台查询具体月份的文章分页列表后,返回前台;
  3. 前台在个人首页的下右方主区域展示存档文章列表。
文章发布
  1. 用户登录后,在顶部导航栏展示发布文章按钮,点击后进入文章编辑页面;
  2. 文章内容使用markdown格式,编辑完成后点击发布;
  3. 编辑页面包含文章标题、主内容、分类、是否原创、是否公开等信息。
文章管理
  1. 用户登录后,在顶部导航栏展示文章管理按钮,点击后进入文章列表页面;
  2. 对列表后展示删除、修改、分类、权限等按钮,均可进行编辑。
文件列表
  1. 用户点击顶部导航中的下载页面,进入下载资源列表页面;
  2. 下载页面展示可下载资源列表,同时提供上传按钮。
文件上传
  1. 用户在文件列表页面可以点击文件上传按钮上传文件;
  2. 上传文件必须登录。
文件下载
  1. 文件列表中的文件可以直接下载,不需登录,后期考虑引入积分制。

通用异常设计

系统中的异常均需要人工捕获,避免直接出现系统类异常。

500、404等均需要有自定义的友好提示,自定义异常尽可能详细,使得前台提示更加清晰。


项目地址

项目代码和文档均以github托管,地址如下:
https://github.com/tuzongxun/tzxblog

这篇关于tzxblog博客系统-概要设计的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/942583

相关文章

Windows系统宽带限制如何解除?

《Windows系统宽带限制如何解除?》有不少用户反映电脑网速慢得情况,可能是宽带速度被限制的原因,只需解除限制即可,具体该如何操作呢?本文就跟大家一起来看看Windows系统解除网络限制的操作方法吧... 有不少用户反映电脑网速慢得情况,可能是宽带速度被限制的原因,只需解除限制即可,具体该如何操作呢?本文

CentOS和Ubuntu系统使用shell脚本创建用户和设置密码

《CentOS和Ubuntu系统使用shell脚本创建用户和设置密码》在Linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设置密码,本文写了一个shell... 在linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设

电脑找不到mfc90u.dll文件怎么办? 系统报错mfc90u.dll丢失修复的5种方案

《电脑找不到mfc90u.dll文件怎么办?系统报错mfc90u.dll丢失修复的5种方案》在我们日常使用电脑的过程中,可能会遇到一些软件或系统错误,其中之一就是mfc90u.dll丢失,那么,mf... 在大部分情况下出现我们运行或安装软件,游戏出现提示丢失某些DLL文件或OCX文件的原因可能是原始安装包

电脑显示mfc100u.dll丢失怎么办?系统报错mfc90u.dll丢失5种修复方案

《电脑显示mfc100u.dll丢失怎么办?系统报错mfc90u.dll丢失5种修复方案》最近有不少兄弟反映,电脑突然弹出“mfc100u.dll已加载,但找不到入口点”的错误提示,导致一些程序无法正... 在计算机使用过程中,我们经常会遇到一些错误提示,其中最常见的就是“找不到指定的模块”或“缺少某个DL

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

Python将博客内容html导出为Markdown格式

《Python将博客内容html导出为Markdown格式》Python将博客内容html导出为Markdown格式,通过博客url地址抓取文章,分析并提取出文章标题和内容,将内容构建成html,再转... 目录一、为什么要搞?二、准备如何搞?三、说搞咱就搞!抓取文章提取内容构建html转存markdown

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

Linux系统之主机网络配置方式

《Linux系统之主机网络配置方式》:本文主要介绍Linux系统之主机网络配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、查看主机的网络参数1、查看主机名2、查看IP地址3、查看网关4、查看DNS二、配置网卡1、修改网卡配置文件2、nmcli工具【通用