三层架构和mvc资料整合
SpringMVC+Spring+Hibernate框架整合原理,作用及使用方法

SpringMVC+Spring+Hibernate框架整合原理,作⽤及使⽤⽅法SSM框架是spring MVC ,spring和mybatis框架的整合,是标准的MVC模式,将整个系统划分为表现层,controller层,service层,DAO层四层使⽤spring MVC负责请求的转发和视图管理spring实现业务对象管理,mybatis作为数据对象的持久化引擎原理:SpringMVC:1.客户端发送请求到DispacherServlet(分发器)2.由DispacherServlet控制器查询HanderMapping,找到处理请求的Controller3.Controller调⽤业务逻辑处理后,返回ModelAndView4.DispacherSerclet查询视图解析器,找到ModelAndView指定的视图5.视图负责将结果显⽰到客户端Spring:我们平时开发接触最多的估计就是IOC容器,它可以装载bean(也就是我们中的类,当然也包括service dao⾥⾯的),有了这个机制,我们就不⽤在每次使⽤这个类的时候为它初始化,很少看到关键字new。
另外spring的aop,事务管理等等都是我们经常⽤到的。
Mybatis:mybatis是对jdbc的封装,它让数据库底层操作变的透明。
mybatis的操作都是围绕⼀个sqlSessionFactory实例展开的。
mybatis通过配置⽂件关联到各实体类的Mapper⽂件,Mapper⽂件中配置了每个类对数据库所需进⾏的sql语句映射。
在每次与数据库交互时,通过sqlSessionFactory拿到⼀个sqlSession,再执⾏sql命令。
使⽤⽅法:要完成⼀个功能:1. 先写实体类entity,定义对象的属性,(可以参照数据库中表的字段来设置,数据库的设计应该在所有编码开始之前)。
2. 写Mapper.xml(Mybatis),其中定义你的功能,对应要对数据库进⾏的那些操作,⽐如 insert、selectAll、selectByKey、delete、update等。
第2讲_Web三层架构+MVC+EasyUI数据库应用开发入门_1

1理解MVCMVC代表: 模型-视图-控制器。
MVC是一个架构良好并且易于测试和易于维护的开发模式。
基于 MVC 模式的应用程序包含:●Models:表示该应用程序的数据并使用验证逻辑来强制实施业务规则的数据类。
●Views:应用程序动态生成 HTML 所使用的模板文件。
●Controllers:处理浏览器的请求,取得数据模型,然后指定要响应浏览器请求的视图模板。
本讲义将覆盖所有这些概念,并告诉你如何使用它们来构建应用程序。
1.1创建一个空的MVC4 Web应用程序运行VS2013,选择菜单“文件 > 新建 > 项目”,项目名为“ChA201_理解M VC”、项目类型为“ MVC4 Web应用程序”,如下图如下。
在新的 MVC 4 项目对话框中,选择“空”模板。
使用 Razor 作为默认视图引擎,如下图。
单击“确定”按钮。
Visual Studio 刚刚创建的 MVC 项目是一个空的项目,完成后查看建立的文件及其下面的文件,如下图。
测试运行,结果如下。
1.2添加一个控制器首先,让我们创建一个控制器类。
在解决方案资源管理器中,用鼠标右键单击控制器(Controllers)文件夹,然后选择“添加控制器”。
命名新的控制器为“HelloWorldController”。
保留默认的模板为“空MVC控制器”,并单击“添加”按钮。
这时,在解决方案资源管理器中会创建一个名为 HelloWorldController.cs 的新文件,并被 IDE 默认打开。
用下面的代码替换该文件中的内容。
public class HelloWorldController : Controller{public string Index(){return"这是一个<b>Default</b>的操作方法";}public string Wellcome(){return"这是一个 Wellcome 的操作方法";}}在上例中控制器方法将返回一个Html字符串。
MVC架构模式实例

MVC架构模式实例⼀、简介 什么是MVC呢?MVC架构模式,也就是Model View Controller模式。
它是⼀种软件设计典范,⽤⼀种业务逻辑、数据、界⾯显⽰分离的⽅法组织代码,将业务逻辑聚集到⼀个部件⾥⾯,在改进和个性化定制界⾯及⽤户交互的同时,不需要重新编写业务逻辑。
MVC被独特的发展起来⽤于映射传统的输⼊、处理和输出功能在⼀个逻辑的图形化⽤户界⾯的结构中。
说起来好像是很复杂,但是我对它的理解也就是各⾃处理⾃⼰的任务。
模型:负责封装并实现应⽤的具体功能。
可以实现系统中的业务逻辑,通常可以⽤JavaBean来实现。
视图:⽤于与⽤户的交互。
⽤来将模型的内容展现给⽤户。
⽤户可以通过视图来请求模型进⾏更新。
视图从模型获得要展⽰的数据,然后⽤⾃⼰的⽅式展⽰给⽤户,相当于提供页⾯来与⽤户进⾏⼈机交互。
⽐如⽤户在登陆注册界⾯完成信息的填报后点击确定,由此来向控制器发出这个请求。
控制器:是Model与View之间沟通的桥梁。
⽤来控制应⽤程序的流程和处理视图所发出的请求。
当控制器接收到⽤户的请求后,会将⽤户的数据和模型相映射,也就是调⽤模型来实现⽤户请求的功能。
然后控制器会选择⽤于响应的视图,把模型更新后的数据展⽰给⽤户。
MVC模式的这三个部分的职责⾮常明确,⽽且相互分离,因此每个部分都可以独⽴地改变⽽不影响其他部分,从⽽⼤⼤提⾼应⽤的灵活性和重⽤性。
⼆、⽬的 使⽤MVC的⽬的是将Model和View实现代码分离,也就是前台html表现层和后台php逻辑层分离。
这样做便于开发,代码优化,界⾯交互性好。
归根结底,其⽬的就是便宜项⽬开发。
三、特点 MVC重要特点就是两种分离:1.视图和数据模型的分离:使⽤不同的视图对相同的数据进⾏展⽰;分离可视和不可视的组件,能够对模型进⾏独⽴测试。
因为分离了可视组件减少了外部依赖利于测试。
(数据库也是⼀种外部组件)2.视图和表现逻辑(Controller)的分离:Controller是⼀个表现逻辑的组件,并⾮⼀个业务逻辑组件。
三层架构详解

三层架构将数据层、应用层和业务层别离,业务层通过应用层访问数据库,保护数据平安,利于负载平衡,提高运行效率,方便构建不同网络环境下的分布式应用;表示层主要作用是接收用户的指令或者数据输入,提交给业务逻辑层做处理,同时负责将业务逻辑层的处理结果显示给用户。
相比传统的应用方式,业务层对硬件的资源要求较低;应用层依据应用规模的不同,所承受的负荷会有较大的差异,另外客户端的数目,应用的复杂程度都会对其造成一定的影响。
ERP三层结构提供了非常好的可扩张性,可以将逻辑效劳分布到多台效劳器来处理,从而提供了良好的伸缩方案;数据层包括存储数据的数据库效劳器和处理数据和缓存数据的组件。
组件将大量使用的数据放入系统的缓存库,以提高数据访问和处理的效率.同时ERP采用大型数据库提供高性能、可靠性高的海量数据存储能力存储ERP的业务数据。
三层架构(3-tier application) 通常意义上的三层架构就是将整个业务应用划分为:表现层〔UI〕、业务逻辑层〔BLL〕、数据访问层〔DAL〕。
区分层次的目的即为了“高内聚,低耦合〞的思想。
概念简介1、表现层〔UI〕:通俗讲就是展现给用户的界面,即用户在使用一个系统的时候他的所见所得。
2、业务逻辑层〔BLL〕:针对具体问题的操作,也可以说是对数据层的操作,对数据业务逻辑处理。
3、数据访问层〔DAL〕:该层所做事务直接操作数据库,针对数据的增添、删除、修改、更新、查找等。
概述在软件体系架构设计中,分层式结构是最常见,也是最重要的一种结构。
微软推荐的分层式结构一般分为三层,从下至上分别为:数据访问层、业务逻辑层〔又或成为领域层〕、表示层。
三层结构原理:3个层次中,系统主要功能和业务逻辑都在业务逻辑层进行处理。
所谓三层体系结构,是在客户端与数据库之间参加了一个“中间层〞,也叫组件层。
这里所说的三层体系,不是指物理上的三层,不是简单地放置三台机器就是三层体系结构,也不仅仅有B/S应用才是三层体系结构,三层是指逻辑上的三层,即使这三个层放置到一台机器上。
第2讲_Web三层架构+MVC+EasyUI数据库应用开发入门_3

3Web界面学生管理系统3.1项目准备参见2.1~2.3步骤创建一个“ MVC4 Web应用程序”的项目“ChA203_学生管理系统”,并准备三层架构的类库,添加JQuery和EasyUI控件,并修改web.config文件。
3.2添加主页控制器添加一个主页控制器HomeController,然后给HomeController的Index方法添加一个同名的视图,即:/Views/Home/Index.cshtml。
3.2.1添加Layout布局主页中首先放上一个Layout;通过body标签来实现布局,可以达到整个页面的布局的效果。
运行一下,如下图。
注意:地址栏中不象以前还要输入控制器中的方法,如:Home/Index就可以了,这是为什么?是由于App_Start/RouteConfig.cs中的RouteConfig类的RegisterRoutes()方法中定义了默认的访问路径为Home/Index,如下图。
public class RouteConfig{public static void RegisterRoutes(RouteCollection routes){routes.IgnoreRoute("{resource}.axd/{*pathInfo}");routes.MapRoute(name: "Default",url: "{controller}/{action}/{id}",defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional } );}}现在有些东西,我们是不希望的:去掉东区域,去掉北区域和南区域的滑动功能(去掉split属性),去掉北区域和南区域的收缩功能(去掉title属性),并调整北区域的高度为50px,调整南区域的高度为25px,调整西区域的宽度为200px;在北区域放一个长江大学教务管理系统的图片,设置西区域的标题为“导航”,设置中区域的标题为“内容”。
ASP.NET三层架构体系分析与应用

据服务层返 回的结果提交给表示层 。 对数据访 问业务的调用是通过 有方便 、 友好 的客户交互界 面。 接 口完成的。 既然与具体的数据访 问逻辑无 关 , 则层与层之 间的关 3、 结 语 系是松散 耦合的 。 果此时需要修改数据访 问层 的具体实现 , 如 只要 基 于AS . T P NE 三层架构的软件开发 已经成为一种流行的开发 不涉及到接 口定义 , 那么业务逻辑层就不会受 到任何影 响。 如 , 例 在 模式, 也带来 了很多开发上的优点 , 适合开发应用需求灵活的系统 , 一 很多系统 中, 用于处理用户方面的业务逻辑 , 以使用Usr uies 可 eB s s n 定程度上保证 了系统的可扩展性和可移植性 。 大型的软件系统开发 类来实现 , 该类使用 Usrnefc接 口, 问S L le类 。 eltrae 访 Q Hep r 一个好的分层式结构 , 可以使开发人员的分工更加明确。 实践 业务逻辑层包含 了业务对象本身以及 应用于它们的规则。 这也 过程 中, 多层架构开 发模式的应用是一条比较好的软件系统开 发途径。 是主要业务对象所在 的位 置。 它们实现业务 实体 或系统对象 。 系统 证明 ,
[] 1 互益祥。 丰住平. 远程无线抄表系统的研 究[]自动化仪表,O , 7、 结 语 J. 2l l [] 2 瞿雷, 刘盛德,胡成斌 .Zg e E技术及应用[ ]北 京: iB e H. 北京航
以上 对 雷 达 物 位 计 从 不 同 的方 面 进 行 了 总体 说 明和 介 绍 , 平 在
的业 务规则将在这些对象 中编 码 , 即从表示层接 收请 求 , 根据 编码 的业务规则处理请求 , 从数据访问层获取数据或将数据发送到数据 访 问层 , 处理结果 传递 回表示 层。 将 23表 示 层 .
MVC与三层架构图

M:JavaBean--模型 V:JSP--显示页面 C:Servlet--控制台访问M客户端(IE 等)Servlet获得客户端数据并把数据封装到域对象中CService:服务处理业务逻辑Dao:数据访问Data Access Object 数据库JavaBean:封装数据JSPV数据显示层:最顶层(第三步)业务逻辑层(第二步)数据访问层:最底层(第一步)DAO接口Service接口cn.itcast.domain:JavaBeancn.itcast.dao:DAO接口Cn.itcast.dao.impl:DAO实现cn.itcast.service:业务接口cn.itcast.service.impl:业务实现cn.itcast.web.controller:ServletWEB-INF/pages:JSP(用户无法访问,但内部可以展现给客户端)cn.itcast.util:工具类cn.itcast.exception:自定义的异常访问1调用专门用来服务的方法3取出数据45存放改变的数据546调用6取出数据7存放数据8取出数据1封装数据2封装数据2传递数据3请求7取出结果8请求转发9显示数据101、无经验就先按逆顺序开发:数据显示层——业务逻辑层——数据访问层2、为降低耦合性(为了抽掉某个部分,整个结构所受的影响不大),采取抽象编程——接口3、Structs2才真正的实现了MVC三层架构4、建模(建立JavaBean)没有建好相当于全挂,搞定了JavaBean,数据库也就搞定了。
Asp.NetMVC+EF+三层架构的完整搭建过程

MVC+EF+三层架构的完整搭建过程2018.11.3 更新:谢谢各位观看如果帮助到你了我也很⾼兴,这是我两年前写的⽂章了,当时⾃⼰也在学习,⼯作了以后才发现这个搭建的框架还有很多的缺点,当然⼊门的话绝对是够了,但是还是推荐下有兴趣的可以去学习下ABP。
如果遇到问题的话,可以去github上看⼀下,在⽂章最后有链接的,当时写的时候,我⾃⼰试过的是可以跑起来的噢。
架构图:使⽤的数据库:⼀张公司的员⼯信息表,测试数据解决⽅案项⽬设计:1.新建⼀个空⽩解决⽅案名称为Company2.在该解决⽅案下,新建解决⽅案⽂件夹(UI,BLL,DAL,Model) 当然还可以加上common3.分别在BLL,DAL,Model 解决⽅案⽂件夹下创建类库项⽬(1).BLL解决⽅案⽂件夹: Company.BLL、Company.IBLL、Company.BLLContainer(2).DAL解决⽅案⽂件夹: Company.DAL、Company.IDAL、Company.DALContainer(3).Model解决⽅案⽂件夹:Company.Model4.在UI 解决⽅案⽂件夹下添加⼀个 Web应⽤程序,名称为Company.UI,选择我们的Mvc模板. 如图:Model层: 选中Company.Model,右键=>添加=>新建项=>添加⼀个实体数据模型名称为Company=>选择来⾃数据库的EF设计器=>新建连接=>选择我们的Company数据库填⼊相应的内容选择我们的Staff表,完成后如图:这时Model层已经完成.我们的数据库连接字符串以及ef的配置都在App.Config⾥,但我们项⽬运⾏的是我们UI层的Web应⽤程序,所以我们这⾥要把App.Config⾥的配置复制到UI层的Web.Config中数据访问层: 因为每⼀个实体都需要进⾏增删改查,所以我们这⾥封装⼀个基类.选中Company.IDAL,右键=>添加⼀个名称为IBaseDAL的接⼝=>写下公⽤的⽅法签名著作权归作者所有。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
WEB三层架构与MVC收藏而我发此文的目的有二:一者,让初学者能够听到一家之言,是为解惑;二者,更希望抛砖引玉,得到专家的批判。
许多学生经常问我,MVC到底和WEB三层架构有啥关系?开始时,我也只能给他们一些模糊的回答。
时间长了,自己的良心开始受到谴责。
对于一个程序员来说,这个问题显得挺学究。
我在跟自己的许多程序员朋友以及同行(Java讲师)都对MVC和WEB三层架构的关系做了探讨。
现在可以说对WEB三层架构和MVC之间的关系理出了头绪。
此可谓教学相长。
先说说Web三层架构这个古老话题。
地球人都知道web三层架构是指:∙>用户接口层(UI Layer)∙>业务逻辑层(Bussiness Layer)∙>持久化层关于业务逻辑和用户接口在早期的web开发中,因为业务比较简单,并没有这三层的划分。
用户数据的呈现及输入的接收、封装、验证、处理、以及对数据库的操作,都放在jsp页面中。
这时的开发,好比盘古尚未开天辟地,整个web开发就是一片“混沌”。
随着业务越来越复杂,人们开始考虑更好的利用OOP这把利刃来解决问题。
于是有人发现把业务逻辑抽取出来并形成与显示和持久化无关的一层,能够让业务逻辑清晰,产品更便于维护。
这就是SUN当初倡导的JSP Model 1开发方式。
关于持久化JSP M1开发方式中,并没有对数据如何持久化给出建议。
在许多公司中,它们的产品是以数据库为中心进行架构和设计的。
在他们的产品里,虽然也有DAO层,但是职责不清。
为什么这么说呢,因为我发现在许多人眼里,DAO层的指责很简单——增删改查。
但我认为,这样理解实际上是本末倒置了。
对于简单数据的管理来说,这样理解无可厚非。
但随着业务逻辑变得日益复杂。
我们实在是被复杂的对象关系搞头疼了,如果这时我们还要考虑如何把数据存储起来(通常的情况下是存到关系型数据库中),我们开始抱怨自己软件的架构太恶心,一团糟。
面向对象设计思想教会我们——如果我们不想做这件事,就交给别人做吧!这时聪明的架构师们提出了一个概念——持久化。
如果我们在自己的应用中添加一个新的层——专门负责对象状态的持久化保存及同步,那不就可以全心全意的“搞对象”了吗?持久化概念的产生,代表着我们对关系型数据库的依赖降低了。
因此甚至有人推断——数据库已死。
同时,关系型数据库这个新的概念也不断形成,并演化成理论,又由理论衍生出产品。
因此一个意识良好的程序员,至少应该认同,持久化并不是产品中最重要的环节——最重要的环节是清晰正确的业务逻辑。
灰色地带是的,从理论上看,web三层架构很美了。
但在实际开发产品的时候,我们发现了很多问题。
主要问题就是用UI层和业务层之间有许多灰色地带。
这些灰色地带业务逻辑层不想管,UI层也不想管。
让我们举一些例子:例子1,难以管理的页面跳转关系上图是我在讲JSP课程时,一个简单案例的页面跳转关系图。
这是一个十分简单的例子,但页面跳转关系已经挺复杂了。
试想,如果你正在做一个有上百张表,十几个核心模块,几百个页面的产品时,这张图将变得多么复杂!而问题是,这些页面跳转关系分散在JSP和Servlet中,非常难以管理。
例子2,表单数据的验证及封装:假设我们正在做一个简单的表单提交,我们希望对用户数据的数据进行验证和封装,最终交给业务逻辑层一个实体对象。
从三层架构分析,我们想要做的事情是这样的:但是该把验证和封装数据的工作交给谁来做呢?UI层还是业务逻辑层?都不太合适!例子3,国际化:如果我们想为不同国家和地区的人提供不同的语言,无疑需要国际化的支持。
那么,我们需要在JSP页面上根据用户的配置或请求信息判断应该为该用户呈现哪国文字。
而这些判断和显示的逻辑应该划分到业务逻辑层还是UI层呢?用MVC的思路解决问题对于纠缠不清的问题,我们总要想办法将其分解。
MVC是一种设计思想。
这种思想强调实现模型(Model)、视图(View)和控制器的分离。
这种思想是如何作用于web的呢?实际上,我们在web开发中引入MVC思想,想要达到的目的是:实现UI层和业务逻辑层分离——控制器是为了实现上述目的而存在的!在解决了持久化的问题后,我们发现,我们的所说的业务逻辑层和MVC中的Model指的是一回事,我们所说的UI层和MVC中的View是一回事。
MVC提供了让模型和视图相分离的思路——引入控制器。
我们把页面跳转关系管理、表单数据的封装及验证、国际化等任务交给控制器处理。
因此,也不难理解为什么流行的MVC框架都具有管理页面跳转关系、表单数据的封装及验证、国际化等特性。
总结在Java web开发中,MVC框架充当了UI层和业务逻辑层的适配器的作用。
MVC框架实现了UI层和业务逻辑层最大程度的分离。
使用mvc的好处,MVC使用规则,java三层架构设计思想java开发web应用MVC使用规则为了提供可重用的设计及代码,M-V-C之间的交互应该很好地定义,以及它们相互间地依赖关系要尽量最小。
使用MVC模式的其中一个目的就是,使一个单一的模型能与多个视图及控制器联合起来。
MVC模型保证了视图能与模型同步。
当控制器从用户输入中接受到一个有效的命令后,它将调用模型上的相应方法。
模型将确认该操作是否与当前的状态一致,然后再执行它,并相应地修改视图的状态。
而视图,作为一个观察者,将根据得到的模型状态改变来更新它的显示。
依赖关系保持最小为了使一个模型能在多个视图及控制器中使用,它们之间的依赖关系必须保持最小。
要做到这些,必须遵守一下规则(如图10-03):注意:A依赖于B,表示A的代码中需要与B相关的信息,如调用B的方法或使用B的属性。
1、模型必须与视图及控制器没有任何依赖关系。
2、视图依赖于与它相关的模型,它必须知道模型状态结构,这样才能把模型显示出来。
3、视图不能依赖与控制器,这样的话,几个不同的控制器可以关联相同视图。
4、控制器依赖于相关的模型及视图,模型定义了控制器能调用的方法,而视图定义上下关系,通过它控制器可以解释用户输入信息。
这使得控制器能紧紧地跟视图联系在一起。
图10-03 MVC模式中允许的依赖关系交互必须保持最小另外一个需要使用多视图及多控制器的前提条件就是保存最小的交互。
特别是,控制器一定不要直接影响与它相关联的视图的显示。
而是在用户输入产生的影响在视图中可见之前,控制器必须与模型进行一个完整的往返交互,这样能保证一个状态修改能更新所有的视图,以及视图能保持与模型同步。
使用单一控制器的实现通常会违反这种规则,因为一些不够严谨的思维:“我已经知道这个状态修改要发生,所以不需要模型来告诉我这个”。
但这是错的,原因有三个:1、模型可能因为某些原因否决该操作,然后这个操作就不会发生了。
2、其他控制器可能同时调用了该模型的操作,有些操作可能也会影响视图的显示,或者使操作不合法。
3、另外,将来使用其他控制器来扩展这个实现也是可能的。
MVC模式是"Model-View-Controller"的缩写,中文翻译为"模式-视图-控制器"。
MVC应用程序总是由这三个部分组成。
Event(事件)导致Controller改变Model 或View,或者同时改变两者。
只要Controller改变了Models的数据或者属性,所有依赖的View都会自动更新。
类似的,只要Controller改变了View,View 会从潜在的Model中获取数据来刷新自己。
MVC模式最早是smalltalk语言研究团提出的,应用于用户交互应用程序中。
smalltalk语言和java语言有很多相似性,都是面向对象语言,很自然的SUN在petstore(宠物店)事例应用程序中就推荐MVC模式作为开发Web应用的架构模式。
MVC模式是一种架构模式,其实需要其他模式协作完成。
在J2EE模式目录中,通常采用service to worker模式实现,而service to worker模式可由集中控制器模式,派遣器模式和Page Helper 模式组成。
而Struts只实现了MVC的View和Controller两个部分,Model部分需要开发者自己来实现,Struts提供了抽象类Action使开发者能将Model应用于Struts框架中。
MVC模式是一个复杂的架构模式,其实现也显得非常复杂。
但是,我们已经终结出了很多可靠的设计模式,多种设计模式结合在一起,使MVC模式的实现变得相对简单易行。
Views可以看作一棵树,显然可以用Composite Pattern 来实现。
Views和Models之间的关系可以用Observer Pattern体现。
Controller 控制Views的显示,可以用Strategy Pattern实现。
Model通常是一个调停者,可采用Mediator Pattern来实现。
现在让我们来了解一下MVC三个部分在J2EE架构中处于什么位置,这样有助于我们理解MVC模式的实现。
MVC与J2EE架构的对应关系是:View处于Web Tier或者说是Client Tier,通常是JSP/Servlet,即页面显示部分。
Controller也处于Web Tier,通常用Servlet来实现,即页面显示的逻辑部分实现。
Model处于Middle Tier,通常用服务端的javaBean或者EJB实现,即业务逻辑部分的实现。
一、MVC设计思想MVC英文即Model-View-Controller,即把一个应用的输入、处理、输出流程按照Model、View、Controller的方式进行分离,这样一个应用被分成三个层——模型层、视图层、控制层。
视图(View)代表用户交互界面,对于Web应用来说,可以概括为HTML界面,但有可能为XHTML、XML和Applet。
随着应用的复杂性和规模性,界面的处理也变得具有挑战性。
一个应用可能有很多不同的视图,MVC设计模式对于视图的处理仅限于视图上数据的采集和处理,以及用户的请求,而不包括在视图上的业务流程的处理。
业务流程的处理交予模型(Model)处理。
比如一个订单的视图只接受来自模型的数据并显示给用户,以及将用户界面的输入数据和请求传递给控制和模型。
模型(Model):就是业务流程/状态的处理以及业务规则的制定。
业务流程的处理过程对其它层来说是黑箱操作,模型接受视图请求的数据,并返回最终的处理结果。
业务模型的设计可以说是MVC最主要的核心。
目前流行的EJB模型就是一个典型的应用例子,它从应用技术实现的角度对模型做了进一步的划分,以便充分利用现有的组件,但它不能作为应用设计模型的框架。
它仅仅告诉你按这种模型设计就可以利用某些技术组件,从而减少了技术上的困难。
对一个开发者来说,就可以专注于业务模型的设计。