软件架构设计文档.docx
《软件架构设计文档.docx》由会员分享,可在线阅读,更多相关《软件架构设计文档.docx(15页珍藏版)》请在冰豆网上搜索。
软件架构设计文档
密级:
内部公开
文档编号:
1002
版本号:
测测(基于安卓平台的测评软件)
软件架构设计文档
文件状态:
[]草稿
[]正在修改
[√]正式发布
文件标识:
开发组
当前版本:
V
作者:
张放、张钰若、陈国忠
完成日期:
2014-5-26
中国石油大学(华东)
计算机与通信工程学院天师团开发团队
:
测测—基于安卓平台测评软件
版本:
<>
日期:
<2014/5/26>
修订历史记录
日期
版本
说明
作者
对软件架构进行初始设计
陈国忠,张放
对软件架构进行初始设计进行修正
陈国忠,张放
确定软件架构
陈国忠,张放
1.文档介绍
文档目的
本文档是对于测测软件系统进行详细设计和编码的重要依据。
对该软件的整个系统的结构关系进行了详细描述,阐述了系统的总体框架,包括物理、逻辑结构,说明了体系结构所采取的设计策略和所有技术,并对相关内容做出了统一的规定。
为今后的设计、编码、测试都提供了可以参考的模版并且提高效率,使整个开发过程做到资源利用最大化,减少由于需求变更而修改的时间,大大的降低了成本,节约了时间,也使得客户更加的满意。
文档范围
本文档包含以下几个部分:
1、架构设计思想
2、架构体系描述
3、系统模块化分
4、系统模块描述
5、模块接口设计
读者对象
本文档主要读者包括:
1、本系统的设计人员:
包括模块设计人员(理解用户需求,在设计时把握用户需求)。
2、本系统的系统开发人员:
编码人员(了解用户需求,为编码提供模版)。
3、本系统的测试人员(了解用户需求,为测试提供参考)。
4、客户(检查是否满足要求)。
参考文献
《软件工程讲义》
《测测需求规格说明书》
2.架构设计思想
为了降低系统耦合度,增加系统内聚性,在需求发生更改时能在较短的时间内对系统做出修改,并重新投入使用,我们决定以分层体系架构风格作为整个系统的体系风格,严格按照一定的规则来进行接口设计,并以之为根据进行详细设计。
分为数据层、业务逻辑层、表示层。
3.架构体系描述
整个系统顶层架构采用分层的风格,整个系统的体系结构非常清晰,使得后期易于详细设计、编码、维护以及适应需求变更。
通过分层,定义出层与层之间的接口,使得在更加规范的同时拥有更为多台花的接口描述,使得层与层之间的耦合度降低,增强了模块的服用型和可扩展性以及可维护性。
同时,分层也有益于项目模块的划分以及任务的分配,通过明确清晰的接口,降低集成的难度,提高效率。
4.views
Modulestructs
(1)具有三层结构的测测软件包图:
图领域模型图
(2)测测软件领域模型图:
图领域模型图
(3)测测软件类图:
图类图
(4)测测系统用例图:
图系统用例图
Component&Connector(组件-连接器视图)
(1)性格测试顺序图:
图性格测试顺序图
Allocation
(1)测测软件部署图:
图部署图
5.Mapppingbetweenviews
ClassmaptoPackage
(1)类图中的TTestController类、UserContainer类、TendencyContainer类对应于包图中表示层的UI包。
(2)类图中的TTest类、User类、Test类、InteligentTest类、CharactTest类、Tendency类、DailyTrend类、ServiceController类对应于包图中业务逻辑层的测试模块包和评价模块包。
(3)类图中的DataHelp类、I/OEventStream类、QuestionBase类、UserInfo类对应于包图中数据层的题库管理包和用户管理包。
PackagemaptoAllocation
(1)包图中的UI包、测试模块包、评价模块包位于部署图中的C/S客户端。
(2)包图中的题库管理包和用户管理包位于部署图中的客户端数据库和数据库服务器。
6.Utilitytree
Qualityattributescenario(质量属性场景)
(1)可用性:
情节描述:
用户在进行性格测试时,点击无反应。
相关质量属性:
可用性
刺激源:
进行性格测试的用户
刺激:
用户点击性格测试
环境:
正常运行状态
制品:
性格测试功能模块
反应:
提示程序无响应,需重启软件
反应度量:
在2s内给出提示
策略:
异常检测
异常处理
(2)互操作性:
情节描述:
用户完成测试,进行提交,数据库返回测试结
果。
相关质量属性:
互操作性
刺激源:
进行测试的用户
刺激:
用户完成测试,进行提交
环境:
正常运行状态
制品:
数据库、测试模块
反应:
显示测试结果
反应度量:
在1s内显示测试结果。
策略:
发现服务
(3)可修改性:
情节描述:
开发人员更新数据库
相关质量属性:
可修改性
刺激源:
开发人员
刺激:
开发人员更新数据库数据
环境:
正常运行状态
制品:
数据库,
反应:
显示测试结果
反应度量:
在1s内显示测试结果。
策略:
减少耦合
提高内聚
封装
(4)性能:
情节描述:
用户完成测试,提交,数据库返回测试结果。
相关质量属性:
性能
刺激源:
进行测试的用户
刺激:
开发人员更新数据库数据
环境:
用户完成测试,提交。
制品:
正常运行状态
反应:
显示测试结果
反应度量:
在1s内显示测试结果。
策略:
同时计算
(5)安全性:
情节描述:
黑客侵入数据库盗取用户密码。
相关质量属性:
安全性
刺激源:
黑客
刺激:
黑客非法侵入数据库
环境:
正常运行状态
制品:
数据库安全保护模块
反应:
阻止黑客获取数据库内容
反应度量:
在1s内进行拦截
策略:
拒绝攻击
反应攻击
确定用户
(6)可测试性
情节描述:
在开发阶段开发者对自己的模块进行单元测试。
相关质量属性:
可测试性
刺激源:
开发人员
刺激:
对已完成的子系统进行测试
环境:
系统开发中
制品:
被测代码段
反应:
显示代码出错情况
反应度量:
执行测试的时间不能超过2s
策略:
限制复杂性
(7)易用性
情节描述:
用户在完成某一测试后重新进行测试
相关质量属性:
易用性
刺激源:
欲进行重新测试的用户
刺激:
用户点击重新测试
环境:
软件正常运行环境
制品:
相应测试功能模块
反应:
进入该测试,显示测试题
反应度量:
重新跳转到相应测试界面的时间不超过2s。
Utilitytree
质量属性
属性细化
场景ASR
性能
题库更新响应时间
在系统处于正常运行时,为对题库更新做出响应,用户更新题库要在3分钟内完成(H,M)
可维护性
软件更新
软件产商发布了一个新版本,必须尽快安装该版本。
(H,L)
维护人员发现了软件的缺陷,修复该bug。
(H,M)
安全性
机密性
完整性
非维护人员侵入数据库,需在1S内完成拦截。
(H,M)
系统拒绝未经登录的访问。
(H,M)
可用性
发布新版本
网络环境不佳
软件产商发布了一个新软件,该软件是热插拔的。
(H,L)
软件产商发布了一个新软件,支持用户随时进行更新。
(M,L)
用户进行每日运势测评无响应,终端在1S内提示用户网络环境不佳,请打开网络连接。
(M,L)
性能
响应时间
吞吐量
用户提交测评后,系统在内显示测评结果。
(M,H)
100名用户同时在线时,系统每秒能处理150个正常请求。
(M,H)
可修改性
优化算话的复杂性
优化测评结果分析算法,两名开发人员在一个工作日内完成。
(H,L)
Tactics
一,安全性策略:
1、反应攻击
2、确定用户
二,可用性策略:
1、异常检测
2、异常处理
3、实时监听
三,安全性策略
1、加密数据
2、拒绝攻击
3、反应攻击
4、确定用户
四,可修改性策略
1、降低依赖
2、减少耦合
3、提高内聚
4、封装
五,性能策略
1、同时计算
7.Architecture
根据软件的重要需求,确定了本软件所采用的设计模式:
WebService
决定运用该模式的需求:
(1)客户端数据库与服务器同步,采用双数据库实现效率提高。
(2)需调用API,进行每日运势分析。
WebService调用每日星座运势API核心代码如下:
privatevoidupdateEverydayFortune(){
if(isNetworkAvailable()){tart();
}
}
privateclassupdateEverydayFortuneRunnableimplementsRunnable{
SimpleDateFormatsimpleDateFormat=newSimpleDateFormat("yyyy-MM-dd");
Stringnow=(newDate());
SharedPreferencessharedPreferences="xzlm",;
@Override
publicvoidrun(){
etString("rank");
Stringaqys=
(1).getString("rank");
Stringgzzk=
(2).getString("rank");
Stringlctz=(3).getString("rank");
Stringjkzs=(4).getString("value");
Stringstzs=(5).getString("value");
Stringxyys=(6).getString("value");
Stringxysz=(7).getString("value");
Stringspxz=(8).getString("value");
Stringzhgs=(9).getString("value");
Stringdate=(11);
etState()=={
returntrue;
}
}
}
}
returnfalse;
}
MVC(ModelViewController)
决定运用MVC模式的需求:
(1)实现测试题目选项统计,进行测试结果分析。
MVC核心代码如下:
etNewPaper();
}
}
}
//测试:
//////////////////////////////////////////////////////////////
publicstaticvoidmain(String[]args){
//TODOAuto-generatedmethodstub
PostOfficepostOffice=newPostOffice();
//得到个人用户
PersonalSubscriberperson=newPersonalSubscriber();
("智力测试");
//注册观察者
(person);
(enterprise);
//发布订阅消息
();
}