1 / 12
文档名称:

系统架构设计说明书.docx

格式:docx   大小:138KB   页数:12页
下载后只包含 1 个 DOCX 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

系统架构设计说明书.docx

上传人:guoxiachuanyue004 2022/10/4 文件大小:138 KB

下载得到文件列表

系统架构设计说明书.docx

相关文档

文档介绍

文档介绍:该【系统架构设计说明书 】是由【guoxiachuanyue004】上传分享,文档一共【12】页,该文档可以免费在线阅读,需要了解更多关于【系统架构设计说明书 】的内容,可以使用淘豆网的站内搜索功能,选择自己适合的文档,以下文字是截取该文章内的部分文字,如需要获得完整电子版,请下载此文档到您的设备,方便您编辑和打印。设备及巡检系统架构设计说明书
版本号:
2015年11月

本说明书的编写目的是描述系统的架构设计方案,包括系统的软件总体架构设计及使用的框架说明,以及基于该架构的开发流程,并作为指导开发人员、测试人员进行系统开发及测试的依据。

整个软件架构方案采用分层、分布式的部署结构,明确地分离了表现层和业务逻辑,能够保证应用服务逻辑的一致性和稳定性、结构的开放性、功能的可扩展性和可维护性、开发的可并行性,同时采用一些开源的框架,兼顾了经济性。框架是一种特殊的软件,它为软件开发带来了高度的重用性,是无数软件开发人员的多年项目开发经验的总结。在一个优秀的框架上开发应用,而不是从零开始,可以大量缩短项目的开发周期、降低开发风险、增强应用系统的稳定性。
系统总体架构图
系统总体架构如上图所示,按功能可以分为公共管理、设备管理、巡检管理、机房出入等模块;系统根据功能特点与业务需求采用基于web的B/S架构模式,项目基于PHP代码实现,运用CI开源框架,可以运行于Linux和Windows平台;

用户层
Web浏览器(IE、Google)
Web服务器
NginxServer
zx
DTO
zx
DTO
PHP
Controller
DTO
A
DTO
数据访问层
ORM
DAO
odel
OCI
OCI
V
数据库
Oracle
操作系统
RedHatLinux
从架构图中可以看出系统分为四层:
用户层:浏览器
表示层:借助html框架及json数据实现业务层:借助PHP进行业务流程开发。
数据持久层:ORM模型操作数据库
为什么采用这样的四层架构?
通过成熟的开源产品实现各层,同自己编写代码实现,相比之下能缩短开发周期,且架构所用到的开源产品均有很广泛的用户群,经受过实践的考验,质量和性能更有保障。
层与层之间松散耦合,增加代码重用率。
各层分工明确,这样也利于团队的明确分工。系统的总体架构从结构上分为用户层、表示层、业务层、数据访问层以及在层间传递数据的数据传输对象。下面针对各层加以描述。
.用户层
用户层作为客户端程序,用来与用户交互,并把来自系统的信息显示给用户。
系统的用户层采用的是IE浏览器作为交互方
式。
.表示层表示层主要控制页面外观,产生页面逻辑以及对用户输入的数据进行合法
性验证。
系统中主要包括基于Bootstrap框架的JavaScript脚本及基于CI框架的表单验证。其中JavaScript脚本可以增强用户体验,PHP负责视图的功能,由HTML、PHP程序片断和JSON数据构成。
.业务层
业务层处理应用的核心业务逻辑。业务逻辑对象把业务规则、约束、活动和数据结合在一起,Controller负责对这些业务对象的管理。
.数据访问层
数据访问对象把底层的数据访问操作和上层的商务逻辑分开。
CI框架规范定义了Web应用程序的类和文件存放的目录结构。该层次结构由三个层次构成。第一层是上下文,它是一个目录或者是多个目录,用来查找与客户请求关联的Web应用程序。在上下文中存在一个/Application目录,该目录存放应用程序,它包含MVC三层目录,用来实现系统的业务逻辑。/public包含所有样式文件,js文件和图片。CI框架采用但入口方式访问系统,即入口文件只有一个,通过参数控制(c=控制器名&皿=方法名)访问不同控制器的方法以打开不同的页面。
表1-1系统目录结构表
目录名
说明
/datacenter
应用上下文根目录
/public
Css样式表文件,js文件和图片等目录
/uploads
上传的文件目录
/system
框架系统目录
/downloads
可下载的文件存放目录
/Application
/config
系统配置文件目录
/controllers
业务逻辑层目录(控制器)
/models
模型层目录(模型)
/views
视图层目录(视图)

系统入口文件
controllers目录下的系统PHP文件的结构说明见表1-2。表1-2系统PHP文件结构说明表
包名
作用说明
com*.php
系统管理模块相关控制器
sys*.php
公共管理模块相关控制器
equipment*.php
设备模块相关控制器
interface*.php
接口模块相关控制器
check*.php
巡检模块控制器
room*.php
机房出入模块控制器
WEB子系统架构总体功能设计
CI框架
CI是一个实现了MVC模式的框架,对Model、View和Controller都提供了对应的实现组件。如下图所示:
Brower
CI入口文件
控制器(Controller)
控制器的作用是从客户端接受请求,并且通过模型层和和数据库交互,然后选择执行相应的业务逻辑,然后把响应结果返回到客户端(视图层)。
模型(Model)
MVC系统中的Model部分从概念上可以分为两类--系统的内部状态,和改变系统状态的动作。CI为Model部分提供了default对象:所有的Action处理器对象都是开发者从Struts的Action类派生的子类。Action处理器对象封装了具体的
处理逻辑,调用业务逻辑模块,并且把响应提交到合适的View组件以产生响应。
(View)
View通过html+php技术实现,view层提供了丰富的组件库,例如下拉框,列表、翻页等,可以非常好的和系统的controller交互,通过这些标签组件实现数据的录入和展现。
表单验证
对Web应用来说,由于用户的行为是无法预测的,在表单数据在传递给业务类之前,必须保证数据的合法性及有效性,而表单验证是保证数据合法性及有效性的重要手段。对于基于CI框架的表单验证一般有两种方式:基于JavaScript的表单验证(前端验证)及基于php的表单验证(后端验证)。
前端验证:可以针对基本类型(汉字、英文、整型、数字、日期、邮编)的有效性及合法性开发出一些共同JavaScript函数,以备整个系统统一调用。
后端验证:
主要采用基于CIform组件的表单验证。由于前端验证不需要提交服务器,直接在客户端完成,从而减少了服务器的压力,
所以我们优先采用前端验证。
日志处理规范合理的日志记录能让开发人员和维护人员事半功倍,在记录日志时主要考虑对数据的一些敏感操作,如增加和删除修改等,并且日志易读。
CI作为一个开源的强大的php框架,有自己的日志处理方式,运行日志主要保存在/home/wwwroot/default/data_center/application/logs
在application/config/$config['log_threshold']=1/2/3/4,如果为0表示不输出错误日志,可自定义日志输出的级别;
另外,为了方便维护,系统还开发了操作日志记录功能(调用setLog('日志内容')方法),用中文的方式记录主要的操作信息,操作日志目录在/appxj/data_cenetr/logs
共同组件

数据列表是页面的一种常见页面表现形式,而分页功能又是列表的一个不可缺少的功能,分页组件主要为各种形式的数据列表提供一个共同的分页功能。技术上实现为首先查询出总的符合条件的数据记录数,然后每次只查询出一页的数据记录,这种方法对于大数据量的情况性能很好。本系统页面表现基于Ajax技术,实现无刷新效果,组件调用接口要求简洁明了。分页组件主要通过前台js+ajax实现,后台控制器只需按ajax提交的参数返回总的条数和对应页面的数据即可,此处用的组件是基于jquery的datatable组件。
,也是页面常见的表现形式,
树形组件为各种形式的层次结构数据提供一个共同的分页功能。技术上可以分两种实现方法:一是查询出所有的层次节点的符合条件的数据记录,在html页面进行分层显示。考虑到层次结构数据一般数据量不大的特点,我们采用第一种方法。此组件主要用户巡检模块的参数设置,基jfuery勺zTree树形组件。
下拉框组件
对于下拉选项比较多的情况,我们采用基于jquery的下拉组件select2,实现可以在下拉框中模糊搜索匹配,从而快速筛选出想要的下拉选项。
model基类(CI_Model)
针对模型层的model基类继承CI的CI_Model类,实现数据对象的增删改查数据库操作,通过实现query()方法来执行SQL语句,通过result_array()方法来设定返回的数据为二维数组。
controller基类(CI_Controller)
该类作为业务层Controller类的基类,所有业务层Controller类必须继承该类。该类实现