您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 质量控制/管理 > 软件详细设计文档模板(最全面)
研发生产中心文档编号版本A1密级商密A项目名称Xx系统项目来源Xxx系统详细设计说明书(内部资料请勿外传)编写:日期:检查:日期:审核:日期:批准:日期:XX公司版权所有不得复制文档变更记录序号变更(+/-)说明作者版本号日期批准12目录1.引言错误!未定义书签。编写目的和范围错误!未定义书签。术语表错误!未定义书签。参考资料错误!未定义书签。使用的文字处理和绘图工具错误!未定义书签。2.全局数据结构说明错误!未定义书签。常量错误!未定义书签。变量错误!未定义书签。数据结构错误!未定义书签。3.模块设计错误!未定义书签。用例图错误!未定义书签。功能设计说明错误!未定义书签。模块1错误!未定义书签。模块2错误!未定义书签。4.接口设计错误!未定义书签。内部接口错误!未定义书签。外部接口错误!未定义书签。接口说明错误!未定义书签。调用方式错误!未定义书签。5.数据库设计错误!未定义书签。6.系统安全保密设计错误!未定义书签。说明错误!未定义书签。设计错误!未定义书签。数据传输部分错误!未定义书签。IP过滤分部错误!未定义书签。身份验证部分错误!未定义书签。7.系统性能设计错误!未定义书签。8.系统出错处理错误!未定义书签。引言背景此文档的背景编写目的和范围说明写这份详细设计说明书的目的。本详细设计说明书编写的目的是说明程序模块的设计考虑,包括程序描述、输入/输出、算法和流程逻辑等,为软件编程和系统维护提供基础。本说明书的预期读者为系统设计人员、软件开发人员、软件测试人员和项目评审人员。术语表定义系统或产品中涉及的重要术语,为读者在阅读文档时提供必要的参考信息。序号术语或缩略语说明性定义1PMProjectManager,项目经理2参考资料列出有关资料的名称、作者、文件编号或版本等。参考资料包括:a.需求说明书、架构设计说明书等;b.本项目的其他已发表的文件;c.引用文件、资料、软件开发标准等。资料名称作者文件编号、版本资料存放地点使用的文字处理和绘图工具文字处理软件:[编写设计文档使用的文字处理软件,如RedOffice]绘图工具:[使用的UML工具,如Rose、Jude、Visio]设计概述任务和目标需求概述运行环境概述条件与限制详细设计方法和工具系统详细需求分析主要对系统级的需求进行分析。首先应对需求分析提出的企业需求进一步确认,并对由于情况变化而带来的需求变化进行较为详细的分析。详细需求分析详细功能需求分析详细性能需求分析详细资源需求分析详细接口需求分析详细系统运行环境及限制条件分析总体方案确认着重解决系统总体结构确认及界面划分问题。系统总体结构确认对系统组成、逻辑结构及层次进行确认,对应用系统、支撑系统及各自实现的功能进行确认,细化集成设计及系统工作流程,特别要注意因软件的引进造成的系统本身结构和公司其他系统的结构变化。包括:系统组成、逻辑结构及层次确认应用系统结构确认支撑系统结构确认系统集成确认系统工作流程确认系统详细界面划分应用系统与支撑系统的详细界面划分应用系统与支撑系统之间的界面包括系统主服务器与其他服务器的服务范围及访问方式,网络及数据库对应用系统的支撑方式,全局数据的管理与存取方式等。系统内部详细界面划分系统各功能之间的界面包括覆盖范围,模块间功能调用涉及到的系统模块及方法,全局数据格式,系统性能要求等。全局数据结构说明本章说明本程序系统中使用的全局数据常量、变量和数据结构。常量包括数据文件名称及其所在目录,功能说明,具体常量说明等。变量本章说明本程序系统中使用的全局数据常量、变量和数据结构。数据结构包括数据结构名称,功能说明,具体数据结构说明(定义、注释、取值)等。系统详细设计功能结构图系统结构设计及子系统划分对系统的组成及逻辑结构进行设计前确认。划分系统功能模块或子系统(如果有或者有必要,特别是大型的软件系统)。系统功能模块详细设计按结构化设计方法,在系统功能逐层分解的基础上,对系统各功能模块或子系统进行设计。此为详细设计的主要部分之一。用层次图描述系统的总体结构、功能分解及各个模块之间的相互调用关系和信息交互,用IPO图或其他方法描述各模块完成的功能。以上建议采用HIPO图进行功能分解与模块描述,更高的要求建议采用IDEF0方法进行功能模型设计。详细设计应用系统的各个构成模块完成的功能及其相互之间的关系,用IPO或结构图描述各模块的组成结构、算法、模块间的接口关系,以及需求、功能和模块三者之间的交叉参照关系。每个模块的描述说明可参照以下格式:模块编号:模块名称:输入:处理:算法描述:输出:其中处理和算法描述部分主要采用伪码或具体的程序语言完成。对详细设计更高的要求建议用IDEF0图进行各功能模块的设计。如果对软件需进行二次开发(包括功能扩展、功能改造、用户界面改造等),则相应的设计工作应该设立子课题完成。系统界面详细设计系统界面说明应用系统软件的各种接口。整个系统的其他接口(如系统硬件接口、通讯接口等)在相应的部分说明。外部界面设计根据系统界面划分进行系统外部界面设计,对系统的所有外部接口(包括功能和数据接口)进行设计。内部界面设计设计系统内部各功能模块间的调用关系和数据接口。用户界面设计规定人机界面的内容、界面风格、调用方式等,包括所谓的表单设计、报表设计和用户需要的打印输出等设计。此部分内容可能比较多。开发和测试生产环境说明开发环境测试及产品环境-Developmentevnironment:programminglanuague,databaseVs2010-svn-iss+-mysql/sqlserver2005/2008-framwork-Testing&productionenvironment:OS,database-framworkWindwos2003,iis,MySQL,模块设计用例图功能设计说明模块1模块1主要分为以下几个子模块:子模块1、子模块2和子模块N。子模块1设计图功能描述简要描述子模块1的业务功能。输入数据详细描述用户输入的数据(包括任何输入设备)以及这些数据的有效性检验规则。详细描述从物理模型中的哪些表获取数据以及获取这些数据的条件。输出数据详细描述子功能1所产生的数据以及这些数据的表现形式。业务算法和流程从业务角度详细描述根据输入数据产生输出数据的业务算法和流程。数据设计给出本程序中的局部数据结构说明,包括数据结构名称,功能说明,具体数据结构说明(定义、注释设计、取值)等。相关数据库表,数据存储设计(具体说明需要以文件方式保存的数据文件名、数据存储格式、数据项及属性等。)源程序文件说明给出本程序的各源程序文件的说明,包括源程序文件名称及其所在目录,功能说明,包含的前导文件及函数名称等。函数说明具体说明本程序中的各个函数,包括函数名称及其所在文件,功能,格式,参数,全局变量,局部变量,返回值,算法说明,使用约束等。限制条件其他说明模块2模块1主要分为以下几个子模块:子模块1、子模块2和子模块N。子模块1设计图功能描述简要描述子模块1的业务功能。输入数据详细描述用户输入的数据(包括任何输入设备)以及这些数据的有效性检验规则。详细描述从物理模型中的哪些表获取数据以及获取这些数据的条件。输出数据详细描述子功能1所产生的数据以及这些数据的表现形式。业务算法和流程从业务角度详细描述根据输入数据产生输出数据的业务算法和流程。数据设计给出本程序中的局部数据结构说明,包括数据结构名称,功能说明,具体数据结构说明(定义、注释设计、取值)等。相关数据库表,数据存储设计(具体说明需要以文件方式保存的数据文件名、数据存储格式、数据项及属性等。)源程序文件说明给出本程序的各源程序文件的说明,包括源程序文件名称及其所在目录,功能说明,包含的前导文件及函数名称等。函数说明具体说明本程序中的各个函数,包括函数名称及其所在文件,功能,格式,参数,全局变量,局部变量,返回值,算法说明,使用约束等。限制条件其他说明接口设计内部接口外部接口接口说明例如:xx子系统通过xx从xx子系统取得xx等,相关标准,调用示例,可根据需要增加章节描述接口。调用方式例如:内部接口调用:例:/***通过用户服务号码取得该客户认证密码等信息,如果该客户存在返回为0,其他情况参考错误编码*/publicRUserInfogetUserInfo(StringuserNo);数据库设计详见[xxx数据库设计说明书]如果数据库设计内容比较少,则直接在此处描述。系统安全保密设计说明例如:由于存在与外部系统的接口,所以需要考虑访问安全的问题.设计例如:分为数据传输部分,IP过滤部分,身份验证部分.[章节可补充]数据传输部分例如:在部分数据传递的时候,考虑以https协议,需要在部署的时候作相关处理.IP过滤分部例如:可在系统前端通过Filter实现,该Filter实现对该地址访问的IP过滤作用.可信任IP地址通过xml文件进行配置.身份验证部分例如:对信任的用户,颁发身份验证码,通过该标识进行身份识别.系统性能设计系统出错处理例如:为了在系统出现异常情况下给用户以明确的提示,可采用两种方式予以提示:1.使用Javascript的alert()函数直接提示,这主要在输入或修改的情况下使用;2.使用统一的错误界面提示,该界面对应于页面。错误界面样式如下图所示:错误提示:返回“错误提示内容”错误提示界面设计和开发规范【可以列表方式列出设计开发的参考文档的索引,内容较少/关键内容可以章节方式填写】数据库设计规范【参见《XXXX数据库设计规范》】.NET编码规范特别强调:详细请参见《文档规范》这里只做简单阐述,如有变动,会及时同事整个项目组相关人员。(1)不要给类名加前缀。使用PascalCasing风格,不使用匈牙利命名法。(2)要用名词词组来给类型命名。使用PascalCasing风格。(3)类名少用缩写,不要使用下划线字符(_)。(4)基类CBase的文件名为:;(5)泛型类命名:考虑用T来命名参数类型,类如:publicclassListT。(6)接口(Interface)命名规范和类命名规范相同,唯一区别是接口在名字前加上“I”前缀。(7)枚举命名:以复数结尾,表明这是一个枚举,例如:EnumColorButtons(8)结构命名:表明这是一个结构体,例如:StructureCustomerInfoRecord'以Record结尾除使用工具直接生成的类外,其它所有类的功能要有注释,即使只是一个数据对象;非常见功能的API必须要有功能描述的注释。独立的要被应用其他功能所调用的模块的接口和公共API的注释要完备,即包括功能说明、参数和返回值说明。其它情况的API的注释尽量完备,但不强制要求。一次性的流打开后必须关闭和释放。一般地,在流打开后,都有一个trycatch语句,务必加上finally块释放流资源。即使IF,While是单语句,也要使用“{}”来划分程序块。不要有完全为调试使用的日志信息,如(“1”);如要使用,在调试完成后请及时删除。一些常识性代码,不需要写没必要的注释。不要用工具生成没用的注释。代码目录结构系统架构目录结构设计图,如下:结构说明:作用范围包名描述整个程序ContentImages存放图片ScriptsJquery以及样式表等Scripts/jquery-easyui-1.2.6jquery-easyui包数字为版本Scripts/jquery-ui-1.8.20jquery-ui包数字为版本Scripts/jthok-ui自定义的js格式文件Scripts/themesIcon格式图片以及样式Controllers../Controller控制器处理来自浏览器的输入,并返回相应页面给用户。Data../Data放自定义的json文件Models../Models存放模型Scripts../Scripts引入的各种外部js文件Views../Views存放各种类型的试图../注意定义路由规则等../配置文件
本文标题:软件详细设计文档模板(最全面)
链接地址:https://www.777doc.com/doc-7910158 .html