zoukankan      html  css  js  c++  java
  • 项目功能规格说明书

    项目功能规格说明书

    1. 引言

    1.1 编写目的

    此功能规格说明书目的在于将网站想法具体化,并规划开发方向,明确功能需求,以提高开发效率。
    本说明书仅供北航“烫烫烫烫烫”团队(hotcode5)参考。

    1.2 项目背景

    在北航的每一学期开始时,微信群中总是闪现着同学们要课件的身影;在北航的每一学期结束时,QQ群中总是充斥着同学们求考题的辛酸。北航目前最主要的课程资源平台——“课程中心”,由于全权交给授课教师管理,而学生并没有上传资源的权限,导致大部分课程的课件、考题等资源并没有出现在上面。一批批热爱学习的北航学子只得穿梭于各个Q群,四处问询课件和复习资料的踪迹,年复一年。2017年的秋天,在北航压抑了两年的老学长们,终于在一门名叫“软件工程基础”的课上明确了自己的价值——我们需要一个稳定的课程资源共享平台!

    1.3 开发意图

    该平台主旨在于“营造一个优良的课程学习环境”,提供资源共享、博文撰写等功能,让同学们更简单地取得提高成绩的途径,向学霸看齐。

    1.4 用户群体

    该平台面向北航在读的全体学生,无论知识层次或能力如何,都能在该平台找到自己的存在感。

    2. 典型用户

    A君:所谓大佬

    不屑于学院安排的课程,对课外知识涉猎更多,利用平台进行知识与经验的分享。

    用户信息 用户情况
    姓名 A君
    用户身份 某学院大三学生
    知识层次和能力 大牛,在某一学科有一定深入的见解
    生活工作情况 投入大量精力学习,对学习充满兴趣
    用户动机 渴望将自己的收获分享给大家
    用户困难 目前找不到针对北航学生的学习资源分享平台
    典型场景 发布博文,整理自己的学习经验,并将自己的一些成果以资源的形式发布,共大家学习
    用户偏好 可以有其他同学在博文下评论,起到交流的作用,让更多同学看到自己的成果
    用户比例 3%左右

    B君:普通学生

    平时还算用功,单纯希望期末考个好成绩,对得起这一学期的努力。

    用户信息 用户情况
    姓名 B君
    用户身份 某学院大一学生
    知识层次和能力 成绩中等,不算太好也不算太差
    生活工作情况 学习娱乐两不误
    用户动机 期末考试取得高分
    用户困难 大班群里资源太有限
    典型场景 下载考题,准备期末考试,并看一看大神总结
    用户偏好 要是有题解就更好了
    用户比例 40%左右

    C君:成绩较差

    平时浪太多,期末压力大,利用平台进行知识恶补。

    用户信息 用户情况
    姓名 C君
    用户身份 某学院大一学生
    知识层次和能力 能力较差,对知识掌握不牢固
    生活工作情况 基础很薄弱,跟不上老师进度,挂科近在咫尺
    用户动机 想要及格
    用户困难 要考试了,可是翻课件也太难理解了,只怪自己基础太薄弱
    典型场景 通过阅读学长总结的笔记,以及部分同学针对专项总结的解题技巧,对考试有很大帮助
    用户偏好 希望能够有一些深入浅出的讲解,一定狠狠地赞
    用户比例 8%左右

    D君:考研选手

    即将面临研究生考试,有些方,希望能在平台上得到比较靠谱的指点。

    用户信息 用户情况
    姓名 D君
    用户身份 某学院大四学生
    知识层次和能力 成绩中等,不算太好也不算太差
    生活工作情况 抓紧时间,复习考研
    用户动机 考研想取得不错的成绩
    用户困难 手头资源有限,也不知如何高效复习,也不懂考试技巧是什么,希望能有过来人替我讲讲
    典型场景 在考研相关课程上下载考研资源,阅读学长总结的考研心得
    用户偏好 希望能有一些标签,帮助我识别哪些是考研用的,哪些是平时或期末考试用的
    用户比例 30%左右

    E君:刻苦学霸

    学习很努力,善于做笔记,记录自己学习的点滴收获

    用户信息 用户情况
    姓名 E君
    用户身份 某学院大三学生
    知识层次和能力 成绩优良,中等偏上,不属于顶尖学神阵营
    生活工作情况 将学习放在第一位,认真完成作业,及时总结
    用户动机 想要把学习过程中遇到的问题总结一下,一来以后复习的时候可以再回顾,二来供其他同学参考
    用户困难 只能自我总结,也不知道自己总结得有没有道理
    典型场景 将总结的学习笔记以资源或博文的形式发布到平台上
    用户偏好 希望能得到认可或是中肯的评价
    用户比例 8%左右

    3. 产品界面原型设计

    3.1 预定实现功能

    • 核心功能
    • 课程的分类
    • 课程资源的上传和下载
    • 课程基本信息的获取
    • 用户贡献点及其排行
    • Alpha阶段拓展功能
    • 课程的搜索
    • 添加课程
    • 课程资源标签
    • 课程资源的收藏和点赞
    • 课程资源的审核与举报
    • 用户登录/注册
    • 个人资料的获取与编辑
    • 首页公告栏
    • 联系我们
    • Beta阶段拓展功能
    • 课程资源评论区
    • 博文相关功能
    • 私信/消息功能
    • 关注用户
    • 获取用户最近动态
    • 首页推送热门博文

    3.2 界面原型设计(Alpha)

    我们使用MockPlus绘制了Alpha阶段的原型设计,该设计包含所有Alpha阶段中计划实现的功能,并包含少量Beta阶段中计划实现的功能。

    3.2.1 菜单栏

    菜单栏原型设计如下图所示:

    菜单栏位于页面的最上端,供用户在首页课程联系我们三个页面之间相互切换。
    此时菜单栏处于未登录状态,因此最右边的按钮为“登录/注册”,登录后该位置按钮会变为用户昵称“注销”
    主要功能如下表所示:

    元素 功能 验收标准
    登录/注册 弹出登录/注册窗口 在当前界面弹出登录/注册窗口,点击窗口外部窗口消失
    用户名(若登录,出现在登录/注册位置) 进入个人主页 通过新窗口进入用户个人中心
    注销(若登录,出现在登录/注册位置) 注销账号 界面刷新,账号注销
    首页 进入首页 界面切换到首页
    课程 进入课程相关页面 界面切换到选择课程界面
    联系我们 进入联系我们页面 界面切换到联系我们界面

    3.2.2 首页

    首页原型设计如下图所示:
    首页
    其中,公告栏后面为一张背景图片。在Alpha阶段,我们力求首页的简介,因此首页除了公告栏以外不设置其它功能。
    主要功能如下表所示:

    元素 功能 验收标准
    公告栏的某一个公告 查看公告详情 点击后弹出公告窗口,再点击窗口外面的部分窗口关闭

    3.2.3 选择课程界面

    我们点击课程进入选择课程界面。
    选择课程界面原型设计如下图所示:

    其中,“添加课程”功能我们决定暂时不实现。
    主要功能如下表所示:

    元素 功能 验收标准
    课程类别 显示所有课程分类 1.来回点击“开设院系”和“课程类别”,保证切换正常;2.在“课程类别”打开状态下点击“课程类别”,课程类别栏折叠
    开设院系 显示学院列表 同上
    一般专业类(核心通识、学院同理) 1.显示该类别所有课程 在“核心通识类”和“一般专业类”之前切换,保证显示对应的课程;2.点击同一个类别两次,课程不发生变化;3.课程默认按照用户访问热度进行排序
    课程列表中的课程 进入该课程界面 进入该课程界面
    添加课程 (暂时不实现) (暂时不实现)
    搜索 在下拉菜单中选择搜索方式,并在输入框中键入关键字,点击搜索即可进行全局课程搜索 1.尝试不同搜索方式,搜索结果正确;2.如果不键入关键字,需弹出模态对话框,告知用户需键入关键字

    3.2.4 课程界面

    在上图中点击软件工程基础,进入软工课程的界面。
    课程界面原型设计如下图所示:

    该界面为Alpha阶段界面,而Beta阶段要实现的博文功能在课程资源的下方,暂时没有体现在原型图中。
    课程信息中的图片可以为该课程所使用的教材封面,增加课程识别度。
    主要功能如下表所示:

    元素 功能 验收标准
    “返回选课界面”按钮 返回到选择课程界面 返回到选择课程界面
    授课教师的名字 返回到选择课程界面,并以该教师名字为关键字进行课程搜索 搜索结果正确
    我来补充 对课程简介进行修改或补充 弹出课程简介修改窗口
    贡献度排行中的用户名 进入到该用户的个人中心 1.能以打开新窗口的方式正常进入该用户个人中心;2.测试姓名相同,但用户名不同的情况
    课程资源栏中的某一个资源 弹出课程资源窗口 弹出课程资源窗口
    课程资源后的“查看全部” 进入到课程资源分类界面 进入到课程资源分类界面

    3.2.5 课程资源分类界面

    我们点击“查看全部”,进入课程资源分类界面。
    课程资源原型设计如下图所示:

    其中资源中的“♡”表示收藏量(感觉用“☆”代替会更好),如果这个资源被收藏了,那么“♡”会变为“♥”。
    主要功能如下表所示:

    元素 功能 验收标准
    任意资源 点击后会弹出资源窗口 1.无论点击“♡”还是用户名,均需弹出资源窗口;2.点击资源窗口外部,资源窗口消失
    “返回课程界面”按钮 返回软工课程界面 返回的课程界面要正确,不能跑到别的课程界面去
    资源类别(课件、考题、习题……) 查看不同类别的资源 1.点击其他的资源类型,课件会有所改变;2.如果没有对应类型的资源,则需告知用户“没有该类型的资源”;3.点击当前的资源类型,没有任何变化,不会刷新一遍。
    升序、降序排序 在左侧下拉菜单中选择排序方式,点击升序排序或降序排序对该类别资源进行排序 测试多种排序方式,结果正确
    搜索资源 在左侧输入框里键入资源名称关键词,点击“搜索资源”进行全局搜索(全局的体现值得再深入设计) 1.搜索结果完整且正确;2.如果不键入关键字,需弹出模态对话框,告知用户需键入关键字

    3.2.6 资源窗口

    点击上图中的全部课件,弹出该课件的资源窗口。
    资源窗口原型设计如下图所示:

    对于图片文件,窗口中的图片元素可以是文件的预览图;而对于一般文件,窗口中的图片元素为该文件类型的图标。
    评论功能为Beta阶段范畴,在Alpha阶段中暂时不做考虑。
    主要功能如下表所示:

    元素 功能 验收标准
    举报 弹出举报窗口 点击举报窗口外部,窗口消失
    “点击下载”或标签下方“↓”图标 下载课件,下载量+1 1.下载量可以不即时变更,但关闭窗口后再打开一定要有所变化;2.同一个用户多次下载同一资源,下载量不会多次增加
    标签下方“♡”图标 收藏资源,同时图标变为“❤”,收藏量+1,再点击一次则为取消资源 1.测试收藏与取消功能皆正常(Alpha阶段暂不实现查看所有已收藏资源,因此只要有图标变化就好);2.收藏或取消收藏后,关闭资源窗口,回到课程资源界面,刷新,图标和收藏量需有所变化
    好评/差评(在实际版本中用相应图标替代“好评”和“差评”文字) 对资源进行评价,并更新评价数据 1.若未评价,点击好评或差评可以进行评价;2.若已评价,点击未选择的评价可以切换评价;3.若已评价,点击已选择的评价可以取消评价;4.对评价的变更需即时体现在数字上
    上传者后面的用户名 进入该用户个人中心 通过新窗口的形式进入该用户个人中心,原窗口不变

    3.2.7 举报窗口

    我们发现这个zip文件里面是空的,原来是一个骗下载量的资源[滑稽],这时候我们点击右上方的举报,弹出举报窗口。

    这里的功能就不必赘述了,选择举报的原因为“无意义资源”,并在详细原因下方写明“空zip文件”,并点击“举报”按钮,相关信息就会发送至管理员,等待管理员的处理。

    3.2.8 登录/注册窗口

    点击右上角的“登录/注册”按钮,弹出登录/注册窗口。


    点击“登录”按钮和“注册”按钮可以在两个窗口之间进行切换。
    忘记密码功能属于Beta阶段的范畴,在Alpha阶段不做考虑。
    注册窗口中的邮箱暂定只能使用北航的邮箱,这是为了保证一名同学只拥有一个账号,且校外的同学无法获取校内的资源。

    元素 验收标准
    登录/注册切换 1.在“登录”窗口时,“登录”为蓝色状态,在“注册”窗口时,“注册”为蓝色状态;2.不同时存在登录和注册两个窗口
    登录密码 输入内容以暗文显示
    登录按钮 窗口关闭,界面刷新为已登录状态
    注册用户名 1.合法用户名为英文/数字/下划线,长度在12个字符以内,否则为不合法用户名,大小写不敏感;2.若用户输入的用户名不合法,或用户名已被注册,则需要在输入框下方即时进行提示
    注册密码 1.合法密码为英文/数字/下划线,长度在8~20个字符内,否则为不合法密码,大小写敏感;2.若用户输入的密码不合法,则需要在输入框下方即时进行提示;3.输入内容以暗文显示
    注册确认密码 1.若确认密码和密码不符,则需要在输入框下方即时进行提示;2.输入内容以暗文显示
    注册北航邮箱 1.需检测是否为北航邮箱,否则需要在输入框下方即时进行提示;2.需检测该邮箱是否已经被注册过,否则也要提示
    注册按钮 界面会提示用户“确认邮件”,系统会向该北航邮箱发送一封邮件,用户点击邮件上的链接,页面跳转到登录状态的首页,用户信息方存入数据库

    3.2.9 个人中心

    登录成功后,在原“登录/注册”位置会显示用户的头像与昵称,点击即可进入个人中心。
    个人中心原型设计如下图所示:

    在Alpha阶段暂时只实现个人资料主要贡献两个功能。点击“编辑资料”可以变更用户资料,这一功能在访问其他用户的个人中心时是不存在的。

    4. 副作用分析

    感觉最大的副作用还是管理的成本问题:

    • 尽管贡献分这个功能在一定程度上起到了鼓励用户分享资源的作用,但也有可能导致出现一批刷分用户,由此为管理带来许多成本。
    • 一些不允许公布的资源(如部分课程的考题)也可能出现在这个网站上,该如何界定这些资源,如何处理这些资源,是一个值得讨论的问题
    • 上传资源的审核成本较大,要是用户上传了恶意程序该怎么办?如果管理员以身试险,那么管理员恐怕就要遭殃了。如何尽可能减少受害者的出现?
  • 相关阅读:
    Linq To Object
    笔试算法
    给你 n 个非负整数 a1,a2,...,an,每个数代表坐标中的一个点 (i, ai) 。在坐标内画 n 条垂直线,垂直线 i 的两个端点分别为 (i, ai) 和 (i, 0) 。找出其中的两条线
    vue3.0中setup的参数
    力扣算法题
    给你一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?请你找出所有和为 0 且不重复的三元组
    vif 与 vfor优先级
    给你一个长度为 n 的整数数组 nums 和 一个目标值 target。请你从 nums 中选出三个整数,使它们的和与 target 最接近。 /返回这三个数的和。
    /给你一个由 n 个整数组成的数组 nums ,和一个目标值 target 。请你找出并返回满足下述全部条件且不重复的四元组 [nums[a], nums[b], nums[c], nums[
    vue3+canvas随机生成4位验证码
  • 原文地址:https://www.cnblogs.com/hotcode5/p/7732383.html
Copyright © 2011-2022 走看看