ImageVerifierCode 换一换
格式:DOCX , 页数:11 ,大小:58.36KB ,
资源ID:4413648      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/4413648.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(软件功能模块的MVC实现.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

软件功能模块的MVC实现.docx

1、软件功能模块的MVC实现一、软件模块MVC实现1.1软件项目是由模块组成1.1.1软件是由其模块组成在软件开发中,最终需要生产出“软件”产品。但开发出的“软件”是由功 能“模块”组成。根据定义,所谓的软件“模块(module)”是在程序设计中,为完成某一相 对独立功能所需的一段程序或子程序;也可以指是某大型软件系统的一部分。前面我们编写的“用户管理”,我们编写了用户信息的“列表查询”功能, 那么“列表查询”是用户管理软件的一个功能模块。如果我们对“用户”信息进 行管理,还需要有:“新增用户信息”、“修改用户信息”、“删除用户信息”操作。 那么,“新增用户信息”、“修改用户信息”、“删除用户信息

2、”均是“用户管理” 的模块,也称功能模块。我们可以用软件功能模块结构图表示它们的关系。例如, “用户信息管理”的模块组成由下图所示,该图不但表示了其功能模块的组成, 而且表示了其模块结构的设计。图1用户信息管理的功能“模块”组成结构1.1.2软件项目开发是以模块为单位进行我们在软件开发时,或者在编码时,不是无序地进行的,往往是以模块为单 位进行的。例如:用户信息管理包括:新增用户信息、修改用户信息、删除用户信息、 查询用户信息等模块。我们在程序编码时,就分别对它们一个一个进行。【案例1-1】完整实现“用户信息管理”模块中新增、修改、删除、查询功能,并使它们在一个统一界面中操作根据分析与设计,“

3、用户信息管理”中有新增用户信息、修改用户信息、删 除用户信息、查询用户信息子模块。每一个模块有自己的操作界面、自己的访问数据库操作方法、还有自己的控 制器,然后将它们通过主界面集成起来。这样就完成了该案例要求的软件功能模 块的开发。在主界面上,对各个子模块的操作链接进行布局,用户操作后再返回到该主 界面。而每个模块分为界面、逻辑处理、控制器组成,分别由 JSP、Javabean Servlet实现。1.1.3 “用户信息管理”程序结构简介在对软件进行设计时,如果以“程序”的观点进行组织与管理则程序会非常 多、类型也不同,与应用业务的关系不紧密,所以管理起来非常困难。但在开发 软件时,要克服“以

4、程序为单位”的编程思想,而要“以模块为单位”进行开发; 即先划分模块,然后再将每个模块分解成不同的程序文件,则会比较有秩序。例如:用户信息管理包括:新增用户信息、修改用户信息、删除用户信息、 查询用户信息等模块,则程序文件以这些模块分为不同的类型。用户信息管理本身是一个模块,而其又是由子“功能模块”组成,而各模块 又是由多个程序文件组成。而每个功能模块又是由:界面、逻辑处理的 Java类、Servle组成。这三个部分分别表示:视图、模型、控制。视图表示:用户看到的 界面;模型表示:业务数据和业务规则;而控制表示:接受用户的输入并调用模 型和视图去完成用户的需求。现在,将一个软件“模块”,分解为

5、:视图、模型、控制器来分别编码,是 一种广泛流行与应用的设计模式,即: MVC设计模式(Model-View-Controller,Model-模型,View-视图,Controller-控制器)。1.2基于MVC设计模式软件开发概述1.2.1 MVC设计模式概述所谓的设计模式是一套被反复使用、成功的设计总结与提炼。而 MVC设计模式是将软件的代码分为M、V、C三层来实现的一种设计方案。MVC全名是Model-View-Controller的缩写,分别表示:M模型(Model) V视 图(View) C控制器(Controller),它一种软件设计典范。它采用业务逻辑和数据 显示代码分离的方法

6、,并将业务逻辑处理放到一个部件里面, 而将界面、以及用户围绕数据的展开的操作单独被分离出来。 MVC类似于传统软件开发中模块的输入、处理和输出功能,集成在一个图形化用户界面的结构中。1.视图(View)视图是用户看到并与之交互的界面。对老式的 Web应用程序来说,视图就是 由HTML元素组成的界面,在新式的 Web应用程序中,HTML依旧在视图中扮演 着重要的角色,但一些新的技术已层出不穷,它们包括Adobe Flash和像XHTML、 XML、WML等一些标识语言。JSP乍为动态网页常常充当 Web应用的视图。2.模型(Model)模型表示业务数据和业务规则。在 MVC的三个部件中,模型拥有

7、最多的处 理任务。例如它可能封装数据库连接、业务数据库处理这样的构件,这样一个模 型能为多个视图提供数据。由于应用于模型的代码只需写一次就可以被多个视图 重用,所以能提高代码的重用性。模型一般用 JavaBea技术实现。3.控制器(Controller)控制器接受用户的输入并调用模型和视图去完成用户的需求,所以当单击 Web页面中的超链接和发送HTML表单时,控制器本身不输出任何东西和做任何 处理。它只是接收请求并决定调用哪个模型构件去处理请求, 然后再确定用哪个视图来显示返回的数据。1.2.2 MVC设计模式的优缺点作为一种设计模式,MVC即有很多好处,但也有一些缺点。1.MVC的优点MVC

8、的优点表现在:耦合性低、重用性高、可维护性高、有利软件工程化 管理等。2.MVC的缺点由于MVC内部原理比较复杂,理解起来并不很容易。所以,在使用 MVC时 需要精心的计划、需花费一定时间去思考。所以,MVC有调试较困难、不利于中小型软件的开发、增加系统结构和实 现的复杂性等缺点。1.3软件项目功能模块分解与设计以一个学生管理系统软件的开发为例,介绍软件功能模块的分解及实现。1.3.1学生管理系统软件项目的开发某高校需要通过“学生管理软件系统”对学生的相关信息进行计算机管理。 本章以该项目为引导案例,介绍软件的一个模块的 MVC模式的开发。围绕学生的信息有许多,包括:学生基本信息、学生学习信息

9、等。而学生的 学习信息与教师信息、课程信息相关联。为了简单起见,我们暂时以上述信息的 管理为主,介绍其功能的分解与实现。我们简单地将该软件分解为如下几个模块:1、 学生信息管理2、 教师信息管理3、 课程信息管理4、 学生成绩管理为了说明用Jsp+Servlet+JavaBear技术实现MVC方式的开发,我们以“学 生信息管理”模块的实现为案例进行 MVC实现介绍。1.3.2功能模块分解为了技术说明清楚,本项目实现的功能非常简单。本软件分解为四大模块, 分别对教师信息、学生信息、课程信息、成绩进行管理。而学生信息只包括:编 号、姓名、性别、班级、年龄、成绩 6个。图2给出了该软件的模块结构的分

10、解与设计。图2学生管理软件模块设计结构图模块:教师信息管理、学生信息管理、课程信息管理的实现技术基本相同, 下面只以一个模块“学生信息管理”为例,介绍该模块基于 MVC的实现。【案例2】对“学生信息管理”模块进行 MVC设计模式的程序编码与功能 实现。并对该功能的软件设计内容进行表示。实现思路:本案例技术上与要求同案例 1,但是学生信息比较多,包括:学 号、姓名、性别、班级、成绩等。其功能子模块可从图 3中可以看出,即“学生 信息管理”模块包括如下子模块:1)学生信息显示,包括:单个学生信息显示、学生信息列表显示两种2) 学生信息新增3) 学生信息修改4) 学生信息删除14模块模型层的优化上述

11、案例2中模型层中所有的类均有一个共同点,即均是对学生信息的操 作,最终落实到对同一数据库表 student的操作;其次,创建数据库连接等数据 处理代码相同,这些均可以放到一起共用,从而优化模型的处理程序。可以不改变视图层的情况下,对模型层进行优化。即通过一个 Java类存放对数据库表的增加、删除、修改、查询操作的方法,并且这些方法中的逻辑处理 代码不需作任何改变。【案例3】优化学生管理模块,使其模型层的类均放在一个Java类程序文件 中。由于对“学生信息管理模块”代码这些程序代码有许多共同的特征, 则将它们的方法合并到一个类中。这个类取名 StudentModel.java,用以存放对“学生信

12、 息管理”相关的各处理方法。这样,就使得程序代码优化简洁,今后以此原则将 不同的处理放到不同的模块处理模型中,整个程序结构比较合理。、软件集成2.1问题的提出前面介绍了一个功能模块的 MVC实现。但是一个软件是由许多模块组成, 这些模块在运行时可能互相交互,它们的关系有可能很复杂。如果我们没有一个 好的操作界面与组织模式,那么这个软件会很不好使用。另外,当软件的各个模块开发好后,也需要将它们组装在一起形成一个整体, 即完整的软件的实现。这个工作就是软件的集成或称软件的组装。 软件的集成是 软件开发的一个重要任务。2.1.1软件项目的功能模块分解模块化原则是软件设计的重要原则之一。也就是说,在软

13、件开发时一般要对 软件进行模块化。即在设计时,需先将软件分解成不同的模块, 这些模块的功能 能构成软件的整体功能。然后在编码时对这些模块一个一个地实现,最后通过集 成将它们组成这个完整软件。模块化体现了将大事化小,然后各个击破的做事原则。例如,高校学生管理系统不但包括学生信息, 还包括教师信息、课程信息和 学习成绩信息。那么在该软件的开发时就需要将它们分解为不同的模块。 这些模 块构成了学生管理系统(如图1所示)。图1学生管理系统模块组成图1中示意了一个软件的模块分解,分解后的模块还可以如此分解下去, 直 至程序员能理解如何做为止(见对学生信息管理的进一步分解) 。如此对要开发的软件进行模块分

14、解,就是所谓的模块化。软件模块化是软件设计阶段应做的事 情。2.1.2软件的模块集成软件的模块化是为了将大问题变成小问题然后一个一个去实现这些小问题。 软件各功能模块的分解完成后,就可以对这些模块分别进行实现。这些模块是相 对独立的软件,在实现过程中可以单独进行编码与单元测试。当这些模块编码完成并通过单元测试后, 就可以放在一起运行。这个过程就 是所谓的软件集成。由于在软件模块的开发过程中,只是局部功能的实现,它们在一起的相互操 作没有运行过,只是在单元测试阶段模拟了互相调用的测试, 所以当它们在一起 的时候是否能按设计要求运行,也需要进行集成后的测试。其实,最终软件是要通过集成完整软件的组装

15、,完成软件的开发任务。2.1.3软件集成相关技术工作如果软件设计得好,集成时只要将软件的各个模块代码复制在一起, 就完成 了集成工作。但是软件集成是这么简单吗?软件模块在集成前,可能需要一些公共的软件部件先部署好, 即各个模块的 一些共性的部分就需要先实现并在系统中支持各模块的运行。 比如:上述各模块可能均要对数据库进行操作,那么获取数据库连接的处理,就可抽象处理作为一 个公共部件,先开发出来并部署好。如果每个模块都有自己的数据库连接获取的 处理代码,这样既增加了软件的冗余度,也不利于今后代码的阅读与维护。所以,在软件集成前,需要定义与部署软件各模块运行的技术支持, 包括运行互相调用的运行环境

16、与底层的技术支持部件。这些部件提供了各个模块的公共 系统部件,各个业务功能模块在设计时在满足了这些公共部件的接口要求后, 集成时只要复制业务处理模块的代码(公共部分的代码不需要复制) ,就完成了集成工作。总结上述提到的技术工作,包括如下几点:模块运行的公共系统环境部件公共的底层技术支撑部件这些工作是在所谓的软件架构时进行考虑与设计的, 所以又称为软件总体架 构设计。在软件架构设计时,架构师要考虑系统运行环境如何布局、采用何种技 术、与模块的接口标准,以及底层采用何种技术、底层技术的配置与实现等等。有了这些公共部件后,软件各模块按其要求进行编码实现,那么集成起来就 是一件简单的事情。2.2软件架

17、构简介721以架构为中心的开发方法软件开发时先确定软件架构,再基于该软件架构进行并行开发,称为“以架 构为中心的开发方法”。它综合利用了 “分而治之”的方法,利于控制软件复杂 性、提高软件开发效率。所谓软件架构是一种高层设计,是系统开发策略的定义与选择,是关于如何 构建软件的一些最重要的设计决策。这些决策往往是围绕将系统分为哪些部分、 各部分之间是如何交互展开的等问题。 软件架构是团队开发的基础,有了软件架 构,很多技术、标准都以确定,不会由于某个程序员的“即时”发挥而使软件增大后导致的不可控。软件架构是高层设计,而各个模块的设计相对来说属于底层设计, 这些设计 需要在技术上对接。所以在软件架

18、构时就需要考虑这些细节,如各自做什么工作、 接口标准是什么、采用何种技术去实现等等。软件架构作为高层设计,存在着到底设计到什么程度的问题。 如果过多地限 定了底层的内容,可能导致过度设计,不利于今后的开发。其实软件架构设计到“能为开发人员提供足够的指导和限制”的程度就可以。软件的接口与实现的分离的选择、架构设计与底层详细设计的分离程度的选 择等,均是属于架构方面的问题。软件架构的优势在于,有了软件架构设计方案之后,确定了 “架构中包含了 关于软件各元素应如何彼此相关等信息”,从而可以把不同模块分配给不同的小 组进行分头开发。而软件架构(其确定的设计方案)则在这些小组中间扮演“桥 梁”和“合作契

19、约”的作用。每个小组的工作覆盖了“整个软件的一部分” ,各小组之间可以互相独立地进行并行工作,从而实现了“分割问题,各个击破”的 策略。稳定的软件架构是未来软件顺利进行的基础。以架构为中心的开发有利于解 决技术复杂性与管理复杂性问题,所以它有利于大规模软件的开发。222软件架构时的工作内容根据软件架构的定义,软件架构是一种高层设计与决策。软件架构设计是解 决全局性的、涉及不同“局部问题”之间交互的设计问题。这些工作包括与整体 相关的那些内容,如接口和实现分离的设计,表示层、模型层、控制层和数据层 的设计与技术选择等。接口和实现分离的设计,是在架构设计时无需深入到一个子系统的实现细节 中去,而是

20、分而治之,先确定该子系统的接口。接口的设计是先定义了一个子系 统为其他子系统所提供服务的契约。软件架构通过明确每个子系统所要实现的接 口及所要调用的接口,为我们展现了一个软件系统如何分割为多个相互协作的子 系统。又例如,表示层、模型层、控制层和数据层的开发往往需要不同的技术,不 但可以这些层分别分派给不同的小组承担, 而且其选择为各个局部模块提供统一 的技术基础平台。例如:可以选择 JSP+Servlet+JavaBear技术实现MVC模式的 开发,也可以选择Struts2+Hibernate或采用Spring技术实现。这是软件架构时要 考虑与确定的。相对于架构的全局性的设计,对于模块的具体设

21、计属于“局部”的详细设计。 它是在软件架构所提供的“合作契约”的指导之下,众多局部问题被很好地“按 问题广度分而治之”地并行进行。而详细设计针对每个部分的内部进行设计。 随着软件开发的规模和复杂度增加,将架构设计和详细设计分离已成为普遍的做 法。设计和制定系统全局性整体结构这类问题,这就是软件架构的设计。例如,介绍学生管理系统只是一个模块的实现,它的 MVC技术、数据处理 层等属于公共规范与内容,它属于软件架构的范畴;而各个模块的实现,只要在 此“契约规定”下,做好自己的JSP界面、模型层、控制器就可以了。另外,要使该模块能在统一的环境下运行,还需要一个统一运行环境。2.3学生管理系统各模块统

22、一运行环境本章图1所示的学生管理系统模块组成包括:学生信息管理模块、教师信息 管理模块、课程信息管理模块和成绩管理模块。这些模块的实现是可单独实现与 运行的(见实现)。但是,这些模块开发成功后,需要在一个统一的界面中操作 与管理运行(见后图7-3)。设计与开发一个各模块统一的运行界面与环境也是软件架构的任务, 因为它也是软件全局性的工作。2.3.1统一运行界面的设计上述四个模块(学生信息管理模块、教师信息管理模块、课程信息管理模块 和成绩管理模块)均可以独立运行(见 “学生信息管理”模块功能演示(a)(g),其他模块类似)。如果我们不改这些模块的代码,使得它们在一个统一的界面下 运行,则集成工

23、作非常简单(运行效果见图 3、图4所示)。下面介绍统一运行的主界面的设计与实现。图2学生管理系统统一界面设计该统一主界面包括五个部分:Logo区、标头区、菜单导航区、内容区、页 脚区。其中菜单导航区是各个模块的入口地址,即是调用各个功能模块的菜单, 当通过该菜单调用某个模块后,则该模块就在内容区中运行(而不是独立运行)2.学生管理系统主界面运行效果展示参考图2实现的学生管理系统的统一运行主界面见图 3所示。为了简单起见 在该主界面中有一个标头区、菜单导航区、内容区、页脚区四个区。其中菜单导 航区是该系统的四个模块的入口;而内容区是各个模块运行的界面。2.3.2统一运行界面的实现【案例1】设计学

24、生管理系统各模块的统一运行主界面,使学生管理系统四 大模块(学生信息管理、教师信息管理、课程信息管理、成绩管理)在其中以统 一的形式运行。首先分别实现各个模块的程序代码, 每一个模块均有一个URL入口,例如学生信息管理模块为一个servlet,其URL为ListStudentServlet.dOo则在主菜单的导 航区中对应“学生管理”的入口为一个超链接:学生管理 同理,其他模块的入口地址也是类似的超链接, 从而实现了软件各功能模块的集成。软件的各功能模块则可在此统一界面中操作运行。233在主界面中其他模块的集成已经介绍过各模块统一运行主界面的设计与实现,也介绍了一个模块“学生 信息管理”的实现

25、及在主界面中的运行。那么,其他的模块在主界面中集成与运 行是否也相同呢?答案是肯定的!即其他各模块只要分别开发完成,将其程序文件复制到项目 工程中,在left.jsp中修改对应菜单的超链接,则完成了其集成工作,该模块就 可以在主界面中运行了。2.3.4软件集成后程序的组织学生管理系统软件组成包括学生信息管理模块、教师信息管理模块、课程信 息管理和成绩管理模块,以及公共架构部件几大部分。每个模块又有 MVC各个 层次,所以整个软件按模块以及按层次进行布局均是一种结构性设计。H 号 src+ 审 cont rol+ 十 dbut il+i 击 entity+ r model-i-rb WebRoo

26、t+ 凸 css+i a META-INF-& scorejspjJ scoreinfo, j sp- st udent j spj error,jspstudentinserts jsp j Etudmrrtliwt. js口 jJ studentshav. jsp j studentupdatjsp-subjectjspJj subjectinfo. jsp- & teacherjsp j teacher inf o, jspJJ WEB- INI*j foot亡工.jwpJ* left. jspj main, jspj top,jsp图3学生管理系统项目程序结构在图3中,src存放包以及

27、Java类文件,WebRoot中存放文件夹或JSP程序 文件。对一个模块的MVC的开发,需要开发的程序包括实体类、数据处理层、表 示层、模型层、控制层五大部分。但是有了公共架构部件后,很多部件已经在公 共部件中有了,比如数据处理层;另外,实体类是整个软件的公共数据模型,在 软件开发前应设计好,所以数据库表、实体类也已经开发好了。在这样的情况下, 再进行其他软件模块的开发,只要知道如何用数据处理层、对哪几个实体类或数 据库表进行操作,剩下的事就是在这种条件下实现自己的 MVC层这三大部分就 可以了。7.4软件的架构与集成总结软件的开发除了实现各个模块的功能外,还需要一个整体架构用以各模块的 操作

28、运行。所以全局性的功能部件、各业务处理局部模块,是软件开发时两大部 分。如果全局性的架构稳健,则对今后各业务功能模块的顺利开发会有很大的好 处。为了顺利地进行软件开发,首先要进行需求分析工作。由于用户需求非常复 杂,而且非常容易变化,所以在软件开发中如何确定用户的需求、 如何管理好用 户的需求,以及如何满足用户的需求均是软件开发成功与失败的关键。但是,一个软件的架构往往可以脱离用户的业务需求进行独立开发, 而将满足用户需求的工作派给各业务处理模块去完成; 同时,软件架构在技术上能满足各模块的运行与操作要求。这样,我们进行软件开发时,就可以将不稳定的因素 限制在较小的范围内,从而尽可能地降低了风险。所以,一个稳定的、灵活的、可扩展的软件架构是软件顺利开发的前提。但 是什么是软件好的架构呢?我们如何利用好以架构为中心的开发方法呢?

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1