软件项目开发计划书.docx
《软件项目开发计划书.docx》由会员分享,可在线阅读,更多相关《软件项目开发计划书.docx(18页珍藏版)》请在冰豆网上搜索。
软件项目开发计划书
软件开发计划书
项目名称:
基于Android平台跑步运动软件的设计与实现
参与人员:
test1,test2,test3,test4,
test5
1引言3
1.1编写目的3
1.2背景3
1.3定义4
1.4参考资料4
1.5系统动机5
1.6标准、条件和约定5
1.7编写文档的WBS5
2.1工作内容6
2.2主要参加人员7
2.3产品及成果8
2.3.1程序8
2.3.2文件8
2.3.3服务8
2.3.4非移交产品8
2.4验收标准9
2.4.1代码的验收9
2.4.2文档验收9
2.4.3服务验收10
2.5完成项目的最迟期限10
2.6本计划的日期10
3.1开发过程11
3.1.1需求分析11
3.1.2系统设计11
3.1.3编码及测试阶段11
3.1.4文档、产品部署11
3.1.5项目总结11
3.2工作任务的分解12
3.3接口人员13
3.4进度13
3.6关键问题14
4支持条件15
4.1计算机系统支持15
4.2需要用户承担的工作16
4.3需由外单位提供的条件16
5专题计划要点17
5.1开发人员培训计划17
5.2测试计划17
5.3质量保证计划17
5.5安全保密计划17
1引言
1.1编写目的
为了保证项目团队按时保质地完成项目目标,便于项目团队成员更好地了解项目情况,使项目工作开展的各个过程合理有序,有必要以文件化的形式,把对于在项目生命周期内的工作任务范围、各项工作的任务分解、项目团队组织结构、各团队成员的工作责任、团队内外沟通协作方式、开发进度、经费预算、项目内外环境条件、风险对策等内容以书面的方式描述出来,作为项目团队成员以及项目干系人之间的共识与约定,项目生命周期内的所有项目活动的行动基础,项目团队开展和检查项目工作的依据。
本项目开发计划用于从总体上指导《基于Android平台跑步运动软件的设计与实现》项目顺利进行并最终得到通过评审的项目产品。
本项目开发计划面向项目组全体成员。
1.2背景
《基于Android平台跑步运动软件的设计与实现》主要功能是,为广大用户提供一个用于记录用户跑步数据并以多种图标展示数据,方便用户对自己跑步的状态的了解;建立跑步交友社区,让用户跑步不再孤独;播放适合跑步频率的音乐;共享跑步数据与排名;给跑步增加乐趣。
项目周期为3个月,项目背景规划如表1.1所示
表1.1项目背景规划
项目名称
项目委托单位
任务提出者
项目承担单位(人)
基于Android平台跑步运动软件的设计与实现
巨硬
巨硬
随着群众对健康的关注,一部分人选择跑步作为自己的一项长期的运动项目。
伴随着近几年中国参与马拉松运动的人数增长,马拉松的热潮席卷全国。
人们对于长跑的热爱也催生了他们对于自己跑步的状态的关注,如果方便的获取跑步时的数据成了人们关注的问题。
在这一背景下,开发基于移动端的跑步运动软件就孕育而生,但是到目前为止已有很多跑步软件面世。
虽然现在的跑步软件众多,但是功能却五花八门,基于用户需求而产生的软件就是我们需要关注和开发的方向。
1.3定义
专门术语:
SQLSERVER:
系统服务器所使用的数据库关系系统(DBMS)。
SQL:
一种用于访问查询数据库的语言
事务流:
数据进入模块后可能有多种路径进行处理。
主键:
数据库表中的关键域。
值互不相同。
外部主键:
数据库表中与其他表主键关联的域。
ROLLBACK:
数据库的错误恢复机制。
缩写:
系统:
若未特别指出,统指本了吧了游戏平台。
SQL:
StructuredQueryLanguage(结构化查询语言)。
ATM:
AsynchronousTransferMode(异步传输模式)。
UML:
统一建模语言、是一套用来设计软件蓝图的标准建模语言,是一种从软件分析、设计到编写程序规范的标准化建模语言。
UDP:
UserDatagramProtocol是无连接的传输层协议
分布式代理:
可隐藏服务器ip,减少服务器的危险;
服务器代理:
可验证用户数据的正确性,以及安全性,进行处理
三级代理:
减轻服务器压力,可实现智能作弊系统!
1.4参考资料
文档格式要求按照我国GB/T8567-1988国家标准和IEEE/ANSI830-1993标准规范要求进行。
包括以下文件:
Ø游戏传输关系系统需求说明书
Ø软件工程项目开发文档范例
Ø软件工程国家标准文档
Ø需求说明书
Ø软件需求说明书编写规范
书籍包括:
Ø《软件项目管理》朱少民,韩莹编著,人民邮电出版社。
Ø《软件项目管理》RajeevTShandilya编著科学出版社。
1.5系统动机
基于Android平台跑步运动软件的设计与实现是为了更好的帮助用户记录自己跑步的数据和多方位的展示自己的跑步数据,用于让用户更好的了解自己的跑步信息,这样有助于用户对自己运动状态的了解。
此系统有助于跑步爱好者制定自己的跑步计划,从而更好的提升自己,系统前期将完全按照用户的需求开发功能,为了吸取用户。
并且会加入许多跑步增加积分的小游戏,让跑步用户在跑步的同时添加更多的乐趣。
在后期,会加入一些广告,用户回收投资,并且会定期通过软件向用户推送近期的跑步活动,从而可以通过活动获取资金。
1.6标准、条件和约定
本项目遵从以下标准:
GB/T13702-1992计算机软件分类与代码
GB/T20918-2007信息技术
GB/T19003-2008软件工程
GB/T5538-1995软件工程标准分类法
GB/T9386-2008计算机富安居测试文档编制
GB/T9385-2008计算机软件需求规格说明
GB/T5532-2008计算机软件测试规范
GB/T18221-2000信息技术程序设计语言
GB/T11457-2006信息技术软件工程
GB/T8567-2006计算机软件文档编制规范
1.7编写文档的WBS
编写文档任务
任务调度收集材料分类编写检查验收总结成果
任务规划实际考察目录章节阶段检查阶段总结
任务分配网上资源详细编写汇总检查汇总总结
2项目概述
随着群众对健康的关注,一部分人选择跑步作为自己的一项长期的运动项目。
伴随着近几年中国参与马拉松运动的人数增长,马拉松的热潮席卷全国。
人们对于长跑的热爱也催生了他们对于自己跑步的状态的关注,如果方便的获取跑步时的数据成了人们关注的问题。
基于此问题,android跑步运动软件应运而生。
android跑步运动软件可以很方便的帮助用户实时记录自己的跑步轨迹,和各种跑步数据,并且以多种多样的图表展示数据。
用户可以从图表中很方便的知道自己的跑步数据,并且可以和以前的数据进行比较,从而知道自己最近几天的跑步状态的变化。
android跑步运动软件采用目前比较流行的C/S模式,AndroidStudio做为开发工具,后台用数据库管理系统用Mysql,系统的运行平台卫Android。
系统运行在每个用户的Android手机上,对上传到服务器的数据的并发访问处理有Mysql控制。
本Android跑步运动软件子要实现的功能如下:
记录跑步各种数据用于展示与储存
用于给跑步增加娱乐性
播放适合跑步频率的音乐
共享跑步数据与排名
建立和维护跑步交友社区
(还有后续用户的需求)
2.1工作内容
1、制作和修订项目开发计划;
2、进行计划跟踪与监控;
3、配合SQA的质量保证工作;
4、工作产品及时进行受控管理;
5、按计划提请阶段评审;
6、提交测试部门评测开发产品;
7、交付最终工作产品;
8、项目实施总结;
9、项目验收。
2.2主要参加人员
为了完成Android跑步软件的项目开发,HN01班组建了一个临时的项目团队——巨硬,有项目经理、软件需求师、软件架构师、软件工程师、数据库工程师、UI设计师、质量控制员、文档人员、测试人员,如图2.1所示。
图2.1项目团队组织结构图
表2.1人员分工
姓名
角色
工作描述
test1
组长
项目经理、软件工程师、软件架构师
test2
组员
软件架构师、数据库工程师、软件工程师
test3
组员
需求工程师、UI工程师、软件工程师
test4
组员
测试人员、质量控制员、软件工程师
test5
组员
文档人员、测试人员、软件工程师
2.3产品及成果
软件名称:
巨硬跑步
编程语言:
Android
存储方式:
硬盘
功能:
对用户的跑步数据进行存储和展示
Ø用户操作手册:
本手册详细描述软件的功能、性能和用户界面,使用户对如何使用该软件得到具体的了解,为操作人员提供该软件各种运行情况的有关知识,特别是操作方法的具体细节。
Ø软件维护手册:
主要包括软件系统说明、程序模块说明、操作环境、支持软件的说明、维护过程的说明,便于软件的维护。
计划提供以下服务:
课堂培训:
以讲课形式对客户进行培训,使其能够正确使用软件。
免费咨询:
客户可以在工作时间向技术人员提出问题并获得解答。
技术支持:
对于某些客户,采取上门指导的方式。
软件维护:
获取软件使用中的问题,提供补丁程序。
升级通知:
在软件新版本发布的时候,及时通知(Email或邮寄信件)注册的用户,并提供试用版本。
软件升级:
对于注册用户,只需较少的费用即可升级到新的版本。
Ø可行性分析报告:
说明该软件开发项目的实现在技术上、经济上和社会因素上的可行性,评述为了合理地达到开发目标可供选择的各种可能实施方案,说明并论证所选定实施方案的理由。
Ø项目开发计划:
为软件项目实施方案制订出具体计划,应该包括各部分工作的负责人员、开发的进度、开发经费的预算、所需的硬件及软件资源等。
Ø软件需求说明书(软件规格说明书):
对所开发软件的功能、性能、用户界面及运行环境等做出详细的说明。
它是在用户与开发人员双方对软件需求取得共同理解并达成协议的条件下编写的,也是实施开发工作的基础。
该说明书应给出数据逻辑和数据采集的各项要求,为生成和维护系统数据文件做好准备。
Ø概要设计说明书:
该说明书是概要实际阶段的工作成果,它应说明功能分配、模块划分、程序的总体结构、输入输出以及接口设计、运行设计、数据结构设计和出错处理设计等,为详细设计提供基础。
Ø详细设计说明书:
着重描述每一模块是怎样实现的,包括实现算法、逻辑流程等。
Ø测试计划:
为做好集成测试和验收测试,需为如何组织测试制订实施计划。
计划应包括测试的内容、进度、条件、人员、测试用例的选取原则、测试结果允许的偏差范围等。
Ø测试分析报告:
测试工作完成以后,应提交测试计划执行情况的说明,对测试结果加以分析,并提出测试的结论意见。
Ø开发进度月报:
该月报系软件人员按月向管理部门提交的项目进展情况报告,报告应包括进度计划与实际执行情况的比较、阶段成果、遇到的问题和解决的办法以及下个月的打算等。
Ø项目开发总结报告:
软件项目开发完成以后,应与项目实施计划对照,总结实际执行的情况,如进度、成果、资源利用、成本和投入的人力,此外,还需对开发工作做出评价,总结出经验和教训。
Ø软件问题报告:
指出软件问题的登记情况,如日期、发现人、状态、问题所属模块等,为软件修改提供准备文档。
Ø软件修改报告:
软件产品投入运行以后,发现了需对其进行修正、更改等问题,应将存在的问题、修改的考虑以及修改的影响做出详细的描述,提交审批。
Ø源程序:
软件开发过程中的全部代码以及注释。
2.4验收标准
最后在发布之前进行小组内评审,代码编写符合HB6465标准,与文档说明保持一致,代码书写风格统一,采用标准规范,没有下列错误:
由于软件缺陷造成丢失数据,不符合设计要求,响应时间太长无法接受等问题。
2.4.2文档验收
最后在发布之前进行小组内评审,文档格式符合HB6465标准,功能符合需求要求,清晰易读,没有语病与歧义。
2.4.3服务验收
服务硬件达到文档说明的要求,人员技术考核合格,定期上门维护。
2.5完成项目的最迟期限
发布日期
从2016年9月10日开始至2016年12月19日,完成对整个系统的可行性报告分析、需求分析说明书、开发计划说明说、系统设计书、项目测试、项目总结,对概念模型、存储模式、完整性控制、存取权限等进行了定义,对系统功能各模块进行了详细设计,定义了数据库总体结构、编码命名规范,并发布。
发布日期为2016年12月20日,延期发布日为1月5号。
2.6本计划的日期
本系统由X老师提出,自2016年9月7号正式批准,审查者为X老师,批准人为X老师。
3实施总计划
3.1开发过程
3.1.1需求分析
需求分析是整个设计中重要的一环,当可行性分析完成,项目立项,确定开发角色后,从9月10开始至9月20日,有关的设计开发人员与相关业务人员共同对业务流程、管理方式进行分析,并进行资料的收集、整理。
在完成了对有关数据信息的收集、归纳和分析整理后,确定了用户需求,对软件必须完成的功能进行了定义,在此基础上完成了数据定义,建立了数据字典。
3.1.2系统设计
从9月21日开始至10月1日,完成对整个系统的分析设计,对概念模型、存储模式、完整性控制、存取权限等进行了定义,对系统功能各模块进行了详细设计、定义了数据库总体结构、编码命名规范。
3.1.3编码及测试阶段
从10月2日开始至11月22日,完成程序设计和系统测试,完成了数据库建立及程序的编制调试。
为了避免错误积累,采用边开发边测试的基本模式,对每个模块都安排专人进行单独测试,系统联调及系统测试,对系统处理逻辑、例外处理能力、容错能力等进行大规模的测试,对发现的问题进行彻底纠正。
3.1.4文档、产品部署
从11月3日开始至11月6日,完成用户培训工作,编写各类文档,系统投入运行阶段。
3.1.5项目总结
项目结束后用一周左右时间,对项目研发、部署等开发过程中的问题、经验教训总结备案,以利于项目经验的积累和开发进的的缩短。
3.2工作任务的分解
表3.1工作情况
工作内容
负责人
参加人员
项目的可行性分析(项目可行性分析报告)
test1
全体人员
项目开发报告(报告)
test1
test1
需求分析(需求分析规格说明书)
test3
test3
系统分析(概要设计及说明书)
test1
test1,test2
详细设计(详细设计说明书)
test1
test1,test2
数据库建立
test2
test2
界面设计
test3
test3
测试计划(报告)
test4
test4,test5
测试报告(报告)
test4
test4,test5
项目开发总结报告(报告)
test1
test1
用户操作手册(报告)
test5
test5
用VISIO绘制数据流图、E-R图等各种图形
test2
test2
软件安装、测试
test4
test4,test5
用户培训
test5
test5
后期维护
test1
全体人员
3.3接口人员
负责本项目同用户的接口人员为test5,由软件发开方派专人,按客户要求,指定地点安装,调试,运行并给客户演示,在后期中负责维护和更新。
3.4进度
方法:
采用结构化开发
设置模块开发优先级:
通过对游戏平台的特点和信息流程等的分析,确定各模块开发的先后次序。
具体开发进度安排如下:
注:
有四个里程碑,分别是需求完成时、详细设计完成时、系统编码完成时、整个项目工作完成时。
表3.2里程碑事件
里程碑名称
产品名称
提交日期
责任人
3.5预算
表3.4表劳务的预算(人员成本/月)
参与人员
时间(月)
预算(元)
test1
3
0
test2
3
0
test3
3
0
test4
3
0
test5
3
0
表3.5经费的预算
办公费
0
差旅费
0
机时费
0
资料费
0
通讯设备
0
专用设备
0
总费用支出
0
3.6关键问题
表3.6项目风险因素
风险排序
风险项名称
风险描述
风险缓解方案
1
专业基础知识不牢
本次项目开发过程中涉及的知识较多,给项目开发人员带来一定的困难
进行相应的培训
2
经验欠缺
成员开发经验不足,使项目质量难以保证
只有通过不断的实践
3
软件性能的影响
本次开发过程中部分软件可能容易出现死机现象
选择合适的软件,搭建良好的配置开发环境
影响本计划完成的主要问题有:
Ø没有经费和硬件设施有限
Ø用户需求不清,存在误解及二义性
Ø第一次开发软件,开发人员没有实际经验
Ø时间有限,没有足够的开发时间
4支持条件
4.1计算机系统支持
开发时需要的支持条件:
Ø硬件:
服务器:
PentiumIII500以上或更高,
内存:
512M以上;
硬盘:
至少80G以上;
CD-ROM:
32倍速以上;
网络适配器:
10MB/100MB自适应;
打印机一台
UPS(选配)
工作站:
Pentium4以上微机;
内存:
512MB
硬盘:
至少80以上;
CD-ROM:
32倍速以上;
网络适配器:
10MB/100MB自适应
网络:
至少一台服务器
至少一台工作站
使用TCP/IP协议的局域网
Ø软件:
操作系统为Android,使用集成开发工具AndroidStudio,数据库采用Mysql,项目运行环境为Android4.X.
运行时需要的支持条件:
一、服务器的要求
1.服务器的中央处理部件(CPU)建议使用PIII1G(以上)Xeon处理器芯片。
2.服务器内存必须使用服务器专用ECC内存
3.为了保证数据存储的绝对可靠,硬盘应使用磁盘冗余阵列(RAID01)
4.为了防止服务器不可预测的故障,或者服务器的定期维护对公司整个业务造成的影响,所有建议使用两台服务器。
两台服务器应构成双机热备份。
中间使用Watchdog电路。
这样的结构可以保证整个系统的长时间不间断工作,即使在服务器定期维护的时候也可以使用后备另一台服务器工作。
5.服务器应支持热插拔电源
6.服务器必须配备UPS(不间断电源)。
7.服务器应该放在学校内部。
不然无法进行程序调试。
8.服务器应该必须有固定IP地址。
9.其他性能在经济条件允许的情况下,应该尽量使用高速稳定的配件。
二、服务器上应该配备的软件
1.操作系统:
MicrosoftWindows2000server或者MicrosoftWindows2000Advancedserver
2.数据库:
MicrosoftSQLServer2005(简体中文版)
3.服务器必须使用专业的防火墙和反病毒软件。
4.除了为了运行必须配备的程序以外,服务器上建议尽量不要安装其他无关程序,以减少程序的混乱或者程序的意外冲突。
5.各系的操作系统尽量统一。
(Windows9x系列或者Windows2000系列)。
这样可以避免管理软件因为操作系统版本不一致造成的过多的开销。
6.各系的机器必须也安装反病毒软件和防火墙。
以防止网络上的蠕虫病毒在整个网络范围内的蔓延。
7.如果要打印涉及字段比较多的报表,应该配备针式打印机。
4.2需要用户承担的工作
填写调查问卷
4.3需由外单位提供的条件
本系统为独立开发,不需要外单位提供条件。
5专题计划要点
5.1开发人员培训计划
2016年9月10日起,至2016年9月20日,共十天实习期间,上午进行软件工程项目开发各项内容的专题知识讲座;下午进行开发设计。
表5.1小组培训内容
培训内容
时间
参加者
配置开发环境
2016-9-10
小组所有成员,有test1和test2培训
GPS的调用
2016-9-11
小组所有成员,有test1和test2培训
数据的呈现
2016-9-15
小组所有成员,有test1和test2培训
Android培训
2016-9-17
小组所有成员,有test1和test2培训
5.2测试计划
2016年11月10日—2016年11月22日对软件进行各项测试工作;
5.3质量保证计划
严格按照项目开发过程中的各项步骤,从项目立项,可行性研究报告、需求分析报告、项目开发计划等,具体实施;
5.4人员配置计划
该项目开发小组共5人:
组长:
test1
组员:
test2、test3、test4、test5。
5.5安全保密计划
在从项目开发阶段到最后软件的正式发布期间,做好项目的保密工作,小组成员对所有项目所有相关文档进行加密,做好备份工作。