以下里程碑基本是参考老师给出的拆分的
程序功能分析
视频中给出的博客引擎是一个“多用户博客引擎”,它具有以下功能:
用户功能:用户可以注册、登录、退出系统
发布博客:用户可以创建、修改、查看、删除自己的博客
评论功能:任何人都可以对博客进行评论
标签功能(不做):用户在创建博客时可以指定一个或者多个标签,方便对博客归类
管理员功能:管理员拥有比普通用户更高的权限,可以管理所有用户以及他们的博客、标签等,还可以把某个用户设为管理员
注意,由于“标签功能”在需求上有点不太清楚,我们就不做了,忽略它的存在吧。
第1个里程碑:搭架子
第一个里程碑主要是把项目的架子搭起来,方便我们后面的开发。
- 打算采用JavaScript,支持ES6. 具体会用到的库和框架:Express,Bootstrap,react,MongoDB;
- 构建工具用npm;
- 代码提交到github上,并会在README中向别人说明拿到代码之后,如何能在自己的电脑上快速把代码运行起来,看到效果(hello world).
这一步的重点在于,你能够把项目的架子搭起来,能够保证以后遇到问题的时候和需要跟人交流的时候,能够方便地让别人看到你的代码或者效果。
验收条件:
其他人可以方便的获取你的代码
其他人可以通过你的说明文件,在本地将服务器快速的运行起来,看到页面
通过简单的页面可以证明你使用的技术栈和主要的库等已经配置正确
若干篇博客用来记录你的学习收获和疑问
第2个里程碑:博客的增删改查
这个里程碑主要是为了让我们快速上手,实现一些基本的最重要的的功能:“博客的增删改查”。其它的功能(比如用户注册、登录等),可以放在以后。
在这一步,我们可以这样考虑这样一种使用场景:实验室内部的同学需要一个可以写博客的系统用于分享知识。由于我们可以通过物理方式保证只有实验室内部同学才能访问这个系统,不需要考虑恶意用户,所以我们可以把它设计得非常简单。不需要用户系统,不需要权限控制,每个人都可以直接在这个系统上进行博客的增删改查,只要在修改和删除时小心一些就可以了。
验收条件:
任何人都可以添加、删除、修改、查看任何博客
创建博客时,只需要填写“标题”、“内容”、“创建人”并记录“创建时间”即可
修改博客时,只需要填写“修改人”,“修改时间”即可
删除博客时,要向用户发出确认,防止误操作
可以以列表形式查看当前所有博客
代码以“小步”方式提交到github上,并且每个commit都有清楚的描述
若干篇博客用来记录你的学习收获和疑问
注意:
暂不用提供用户相关功能(如注册、登录等),以及评论、标签等功能
由于没有用户功能,所以在创建和修改博客时,需要手动提供“创建人”和“修改人”姓名
如果一篇博客多次修改,“修改人”和“修改时间”记录的是最后一次
不需要记录每次修改的内容,直接保存最后的修改即可
删除博客时,直接从系统中删除
这一步不需要使用真实数据库,可以把数据直接保存在内存中某个变量,或者一个JSON文件里
第3个里程碑:使用真实数据库
使用真实的数据库mongodb来替换前一个里程碑中的模拟数据库。之所以把它单独拿出来,是因为从技术角度上讲,还是有一定的难度,比如数据初始化、异常处理等
验收条件:
前一个里程碑的功能没有被破坏
可以通过某种方式来初始化数据库结构和预置数据,并在README中说明步骤
代码以“小步”方式提交到github上,并且每个commit都有清楚的描述
若干篇博客用来记录你的学习收获和疑问
第4个里程碑:用户登录
在这个里程碑,我们将增加一个重要的功能:用户的注册、登录、退出。这个功能几乎在每个网站中都会用到,非常重要,所以我们尽快实现它。
在这个里程碑中,我们只考虑一种用户“普通用户”(“管理员”放在后面的里程碑)。
验收条件
查看博客时不需要登录
只有注册成用户并登录后,才能创建、修改、删除自己的博客
用户不能修改或删除别人的博客
如果没有登录,则不允许访问“创建、修改、删除”等页面
注册用户时,需要提供以下数据 “用户名”,“密码”。其ID由数据库或代码自动生成,每个用户的ID都是唯一并且不变的
用户登录时,需要输入“用户名”和“密码”
用户登录后,可以退出
用户可以修改自己的用户名和密码
创建或修改博客时,不需要再手动输入“创建人”和“修改人”,而是由系统自动拿到当前用户的ID并使用该ID
注意点
这个里程碑只有一种用户“普通用户”,没有“管理员”,所以没有人可以修改或删除别人的博客
原有的数据库结构需要修改。之前保存的是手动输入的“创建人”或“修改人”姓名,而现在应该使用登录者的ID。当需要显示其用户名时,可以通过ID拿到其用户名
第5个里程碑:博客评论
对于每一篇博客,每个人都可以增加评论。为了简化需求,在评论时,不论用户是否登录,都要求输入用户名,一视同仁。
验收条件
查看每一篇博客时,都可以看到已有的评论,并按某种时间顺序排列
查看每一篇博客时,都可以看到一个输入框输入新的评论,包括“姓名”和“内容”,可以提交新的评论
评论一旦添加,则不可以修改或删除(在后面可以添加该功能)
第6个里程碑:管理员
现在我们可以添加一个新的用户角色“管理员”。它跟“普通用户”的区别在于,它可以对所有的注册用户、所有博客、评论进行增删改查等操作,还可以把别的用户设置为管理员。
验收条件
管理员登录后与普通用户看到的界面有所不同,多了“所有用户”、“所有博客”、“所有评论”的管理功能
管理员可以对“所有用户”、“所有博客”、“所有评论”进行增删改查
管理员可以将某个用户设置为“管理员”,也可以将某个“管理员”设置为“普通用户”
管理员不能删除自己,或者把自己降为“普通用户”
注意
第一个管理员直接在数据库中预先提供
第7个里程碑:管理员增加搜索功能
当管理员管理用户、博客和评论时,可以搜索,以方便管理
验收条件
管理员在管理用户时,可以使用输入的关键字模糊搜索“用户名”,并只显示符合条件的用户
对于博客,只搜索“标题”
对于评论,只搜索评论“内容”
注意
不需要提供分页功能