WEDO 创意论坛技术规格说明书

0x0 文档版本

版本号 说明
v1.0 初步确定技术路线

附Github仓库:WEDO


0x1 技术说明

1. 前端框架

  在主流的前端框架中,我们调研了Vue、BootStrap、AnguarJS、ReactJS等框架。每个框架都有各自的优点,但是考虑到小组成员的前端开发经验较少,最终选择了比较容易上手的BootStrap框架。BootStrap框架拥有很多封装好的UI组件,能够快速地搭建出优质的前端页面。

2. 后端框架

  在选择编程语言的时候,抛开适合写服务器和引擎的C++以及适合高并发场景下的Go,我们讨论并分析了Java、Python、PHP三种语言,分别对应Django、SSM(Spring+SpringMVC+MyBatis)和PHP框架。
  我们小组的开发部门有成员有使用Spring开发的经验。但是因为SSM的学习成本相对较高,需要从Servlet开始,并且一开始上手使用Hibernate或者MyBtis比较麻烦,于是排除了Java。
  根据对PHP的调研,世界上超过80%的网站的搭建都使用到了PHP,基本上大部分论坛以及电商的网站功能,都能使用PHP7实现;另一方面看,PHP7的性能提升了很多,适合于API的开发。同时由于组里开发人员对Python后端开发以及在Django框架下的开发不熟悉,我们小组决定使用PHP(世界上最好的语言)作为我们小组后端的编程语言。
  有关PHP的开发框架,经过对laravel和ThinkPHP两框架的调研后。我们初步确定最后使用Laravel框架。其主要原因是在Lavarel中内置了大量的API供开发者使用,在实际应用中更加贴近面向对象的开发方式。而且Laravel框架拥有大量的中文文档作为参考:Laravel中文社区。另外,从网络安全的角度来看,Laravel更胜一筹。


0x2 服务器平台搭建

  我们准备使用LNMP(Linux + Ngnix + MySQL + PHP)的环境。相较于其他服务器(如Apache),Nginx具有以下两个优点:

  1. 反向代理,能够实现请求的分发,以及对于用户的后台不可见性。
  2. 能够实现负载均衡。这有助于后期对于大流量用户情况的适应。

  但是对于论坛前期的预期运行情况,还不需要考虑服务器压力和性能对于系统的影响,并且最开始只有一台可供使用的服务器。
  对于数据库的选择,我们选择比较常用的MySQL
  考虑到服务器上并不需要桌面环境,所以开发环境预计使用CentOS 6.x | 7.x版本。


0x3 项目技术设计

项目功能抽象

  项目的具体功能已在项目功能设计书中描述,以下为项目功能的初步抽象图:

前端界面设计

  项目具体的前端界面设计已在界面设计计划书中进行描述。

后端实现设计

路由路径设计

  项目后端的路由分发路径如下图所示:

数据信息存储

  所有的数据存储至后端的MySQL数据库中。数据在数据库的组织方式如下图所示:

  各数据的详细类型及规定如下表所示:

数据表名 属性名 属性类型 是否为主属性
User uid int(8) Yes
user_name varchar(32)
password varchar(256)
user_kind int(8)
user_regTime timestamp
user_email varchar(32)
user_info varchar(128)
Project pid int(8) Yes
project_name varchar(32)
project_kind int(8)
project_createTime timestamp
project_progress int(4)
project_info varchar(512)
Workgroup gid int(8) Yes
group_name varchar(32)
group_regTime timestamp
group_kind int(8)
Comment cid int(8) Yes
pid int(8)
uid int(8)
comment_time timestamp
comment_info varchar(256)
comment_thumbs_up int(8)
Reply rid int(8) Yes
cid int(8)
uid int(8)
reply_time timestamp
reply_info varchar(256)
reply_thumbs_up int(8)
ProjectOwner pid int(8) Yes
uid int(8)
ProjectDeveloper pid int(8) Yes
gid int(8)
WorkgroupMember gid int(8) Yes
uid int(8) Yes
UserLabel uid int(8) Yes
user_label int(8) Yes
WorkgroupLabel gid int(8) Yes
group_label int(8) Yes

异常处理

  目前,系统中预期中的各个部分异常如下图所示:


[V1-Team] WEDO创意论坛技术规格说明书的更多相关文章

  1. [V1-Team] WEDO创意论坛功能规格说明书

    项目功能规格说明书 版本说明 版本 内容 时间 V1.0 描述总体目标,用户使用场景,界面原型.功能设计及验收 2019.3.28 附Github仓库:WEDO 正文 1.目标 规范指导整个项目设计与 ...

  2. (Alpha)Let's-技术文档(技术规格说明书)

    技术规格说明书 抽象 首先,对抽象原则的理解,“抽象”这一概念本身就很抽象.抽象体现的是一种概括能力.我们生活中遇到的很多客体,其在某些方面具备有一些相似甚至相同的性质,以这些特点而非事物本身来认识鉴 ...

  3. 【Alpha】技术规格说明书

    由于第1周已经写过技术规格说明书(设计文档),本周更新了上一版内容. Github地址:https://github.com/buaase/Phylab-Web/blob/master/docs/Ba ...

  4. [软件工程基础]PhyLab 技术规格说明书

    由于暂不对后端有所改变,因此该部分技术规格说明书复用 Default 的技术规格说明书. 由于现阶段对于 Laravel 框架不熟悉,以及对于是否使用已有的轮子或者造轮子实现预想的功能还不清晰,因此暂 ...

  5. 【近取 key】技术规格说明书

    项目 内容 这个作业属于哪个课程 2021春季计算机学院软件工程(罗杰 任健) 这个作业的要求在哪里 技术规格说明书 我在这个课程的目标是 进一步提升工程化开发能力,积累团队协作经验,熟悉全栈开发流程 ...

  6. 【BUAA软工】技术规格说明书

    项目 内容 班级:北航2020春软件工程 博客园班级博客 作业:技术规格说明书 技术规格说明书 宏观技术 后端 WEB服务器 WEB服务器选取的是Springboot,作为当下Java语言最主流的WE ...

  7. [no_code]OCR表格处理——技术规格说明书

    项目 内容 这个作业属于哪个课程 2020春季计算机学院软件工程(罗杰 任健) 这个作业的要求在哪里 技术规格说明书 我们在这个课程的目标是 远程协同工作,采用最新技术开发软件 这个作业在哪个具体方面 ...

  8. Team++_炸弹人软件需求说明书

    目标是什么,目标不包括什么? 目标是制造一款受青年人(大学生或中学生)喜爱的手机益智闯关游戏,可以用来打发时间或放松心情. 用户和典型场景是什么? 用户:学生 典型场景:在宿舍无聊时.在睡觉之前或在课 ...

  9. 团队作业Week6:规格说明书编写

    (1)请分析你们团队项目的典型用户和场景,并写一个团队博客发布你们团队项目的功能规格说明书. (2)再写一个博客团队博客发布你们项目的设计文档(技术规格说明书). 截止时间:2015-11-03

随机推荐

  1. [GO]猜数字的小游戏

    随机生成四位数字,然后用户输入四位数字,然后根据提示一步步猜到随机数 package main import ( "math/rand" "time" &quo ...

  2. oracle数据库单表查询

    今天给大家分享的是关于数据库的单表查询,像单表查询/多表查询/分组查询/子查询,这些方法的使用在实际项目过程中会经常用到,作为一名合格的测试人员如果不会数据库那肯定是不行的,行走江湖可能随时会面临被侮 ...

  3. 无法解析的外部符号 _WinMain@16(原)

    原来的控制台程序,想修改为windows程序时,会出现 无法解析的外部符号 WinMain,该符号在函数 __tmainCRTStartup 中被引用 在链接器->高级->入口点输入:ma ...

  4. 编写高质量代码改善C#程序的157个建议——建议8: 避免给枚举类型的元素提供显式的值

    建议8: 避免给枚举类型的元素提供显式的值 一般情况下,没有必要给枚举类型的元素提供显式的值.创建枚举的理由之一,就是为了代替使用实际的数值.不正确地为枚举类型的元素设定显式的值,会带来意想不到的错误 ...

  5. 对于网站,APP开发流程的理解

    • 明确产品目标用户,目标市场 • 明确将要开发的产品面世后是要解决什么样的问题 • 梳理产品有哪些功能点,功能点如何按照模块划分 • 站在用户角度思考用户怎样使用这款产品,以故事的情景讲述用户如何使 ...

  6. JS Img对象获取图片高度宽度(兼容Chrome)

    一般获取图片高度宽度的写法: var img = new Image();img.src = imgsrc;var imgWH = CalcImgTiple(img.width, img.height ...

  7. perationalError: (2003, "Can't connect to MySQL server on u'192.168.1.6' (timed out)")

    在Ubuntu(192.168.1.20)中部署项目后,mysql还在另外一台windows(192.168.1.6)机子上,ping windows时可以ping通,但是访问项目提示: perati ...

  8. 321. Create Maximum Number (c++ ——> lexicographical_compare)

    Given two arrays of length m and n with digits 0-9 representing two numbers. Create the maximum numb ...

  9. jmete察看结果树和body data乱码问题的解决办法

    jmeter察看结果树乱码问题的解决办法: (1)在jmeter的bin目录下找到jmeter.properties这个文件添加sampleresult.default.encoding=utf-8 ...

  10. Mysql的用户基本操作

    创建用户: mysql> create user 'cai'@'localhost' identified by '123456'; Query OK, 0 rows affected (0.0 ...