写在前面
上一篇文章中我带着大家进行了权限部分的极简设计,也仅仅是一个基本的权限设计。不过你完全可以基于这套权限系统设计你的更复杂的权限系统,当然更复杂的权限系统要根据你的业务来进行,因为任何脱离实际业务的权限设计都是耍流氓!今天这篇文章我们就对CMS系统的内容进行设计。同时下篇文章准备带着大家理解一下架构设计。
需求分析
由于目前的需求是这个CMS系统要满足一个博客系统的功能。当然一个博客系统首先要有权限系统,这个我们上篇文章里面的权限设计已经能够满足功能了。可光有权限系统还不够,还要有新建文章,发布文章,文章分类的功能。复杂点的还要有文章评论子系统,留言子系统,友情链接子系统,甚至还包含SEO优化的部分,再复杂点就像博客园一样,还包含会员子系统,会员也可以发布文章等等。但是你以为我会把这些都设计进来吗?骚年,你想多了!我们还是慢慢迭代吧,这里先进行博客内容以及博客分类的设计吧!至于其他的功能以后再慢慢迭代吧!同时这个项目我会一直开源在GitHub上,持续的更新,这些功能后期都会有的。 综上,我们的需求很明确:文章管理,以及文章分类管理!文章要求记录阅读量。就这么简单,惊不惊喜?意不意外?哈哈!要不怎么说极简呢?
逻辑模型设计
这次设计的比较顺畅,没有一点点停顿,可以说一步到位,为什么??因为实在是极简啊!不信?我就直接上图了!都不用备注,你就能看懂!当然,设计的PDM文章我今天就会放到GitHub上。地址,在文章最后给出。
是不是很简单,就两张表,可这两张表包含的内容可不少。下面我们就来说道说道
表详细说明
分类表
分类表,顾名思义就是文章的分类,这里分类中有个父分类ID可以进行循环嵌套,这样就可以让分类具有子分类的功能,理论上支持无限嵌套,但是傻瓜才会真的嵌套那么多次吧! 另外分类中加入了SEO相关的标题,关键字,以及描述!什么SEO有什么用?自己百度去。 表中具体的字段我就不一一列举出来了!因为我会把PDM放到GitHub上面,你完全可以使用PowerDesigner打开看一下。
文章表
文章表就是我们的主表了!一切都是为它服务!因为权限系统作为支撑系统,分类作为文章的辅助,而主角肯定是文章表本身了!前台页面展示也都是展示文章的内容。 这里文章我们有浏览量,有了浏览量我们就知道了我们的文章的受欢迎程度。 同时,文章表也加入了诸如,是否轮播图播放,是否置顶,是否热门等等字段,好处是我们可以丰富我们的页面功能,通过这些属性来自定义每个部分显示的文章内容!当然你也可以通过分类进行设置,这个你自由发挥! 既然是博客系统,文章的SEO功能肯定是不能少的,作为我们的主角,肯定也得有SEO标题,关键字,内容字段,让我们可以自定义这些内容,这里有人或许会问了,万一我没写这些字段怎么办呢?当然给默认值了,这里思考下我会怎么给默认值吧! 如果我们看到了比较好的文章,想要转载怎么办呢?这里当然要给你留个来源跟作者的字段了。不然,你不留来源跟作者的话,当心别人会告你侵权哦! 废话有点多,pdm文件我会放到GitHub上,自己去看吧!注释写的又那么全,内容又那么少,理解起来又那么容易,你要再不想看的话,我也没办法了!
GitHub地址
这里我会把权限设计以及内容管理设计的逻辑视图上传到GayHub上,这里给出地址。觉得不错的,可以给个Star!后续我们也会在这个GayHub仓库进行开发的!
GitHub:https://github.com/yilezhu/Czar.Cms 码云:https://gitee.com/yilezhu/Czar.Cms
总结
不善于作总结的程序员不是一个好作者!本篇文章带着大家设计了一下我们将要实战的CMS系统的内容管理模块,也是最核心的模块!但,我们却进行了简单的不能再简单的设计!因为如果进行太详细的设计的话,会严重影响更新的进度,目前已经有很多小伙伴崔更了!!!上篇文章的权限设计以及本篇文章的内容设计的逻辑视图的PDM文件我也已经上传到GayHub上了,有兴趣的朋友可以下载查看! 下篇文章我们就一起聊聊架构设计!