浅谈Java Web经典三层架构和MVC框架模式

开发 架构
首先我们需要知道MVC模式并不是javaweb项目中独有的,MVC是一种软件工程中的一种软件架构模式,把软件系统分为三个基本部分:模型(Model)、视图(View)和控制器(Controller),即为MVC。

 一、MVC设计模式

1.MVC的概念

首先我们需要知道MVC模式并不是javaweb项目中独有的,MVC是一种软件工程中的一种软件架构模式,把软件系统分为三个基本部分:模型(Model)、视图(View)和控制器(Controller),即为MVC。它是一种软件设计的典范,最早为Trygve Reenskaug提出,为施乐帕罗奥多研究中心(Xerox PARC)的Smalltalk语言发明的一种软件设计模式。

[[271839]]

2.MVC的详解

虽然MVC并不是Java当中独有的,但是现在几乎所有的B/S的架构都采用了MVC框架模式,但是MVC在B/S架构中并没有完全地实现,其实我们根本不需要掌握未实现的部分。

·控制器Controller:控制器即是控制请求的处理逻辑,对请求进行处理,负责请 求转发;

·视图View:视图即是用户看到并与之交互的界面,比如HTML(静态资源),JSP(动态资源)等等。

·模型Model:模型代表着一种企业规范,就是业务流程/状态的处理以及业务规则的规定。业务流程的处理过程对其他层来说是不透明的,模型接受视图数据的请求,并返回最终的处理结果。业务模型的设计可以说是MVC的核心。

3.MVC模式的用武之地

MVC模式被广泛用于Java的各种框架中,比如Struts2、Spring MVC等等都用到了这种思想。

Struts2是基于MVC的轻量级的web应用框架。基于MVC,说明基于Struts2开发的Web应用自然就能实现MVC,也说明Struts2着力于在MVC的各个部分为我们的开发提供相应帮助。

二、Javaweb经典三层架构

1.Javaweb经历了三个时期

①JSP Model1第一代

JSP Model1是JavaWeb早期的模型,它适合小型Web项目,开发成本低!Model1第一代时期,服务器端只有JSP页面,所有的操作都在JSP页面中,连访问数据库的API也在JSP页面中完成。也就是说,所有的东西都耦合在一起,对后期的维护和扩展极为不利。

浅谈Javaweb经典三层架构和MVC框架模式

②JSP Model1第二代

JSP Model1第二代有所改进,把业务逻辑的内容放到了JavaBean中,而JSP页面负责显示以及请求调度的工作。虽然第二代比第一代好了些,但还让JSP做了过多的工作,JSP中把视图工作和请求调度(控制器)的工作耦合在一起了。

浅谈Javaweb经典三层架构和MVC框架模式

③JSP Model2

JSP Model2模式已经可以清晰的看到MVC完整的结构了。

·JSP:视图层,用来与用户打交道。负责接收用来的数据,以及显示数据给用户;

·Servlet:控制层,负责找到合适的模型对象来处理业务逻辑,转发到合适的视图;

JavaBean:模型层,完成具体的业务工作,例如:开启、转账等。

浅谈Javaweb经典三层架构和MVC框架模式

这就是javaweb经历的三个年代,JSP Model2适合多人合作开发大型的Web项目,各司其职,互不干涉,有利于开发中的分工,有利于组件的重用。但是,Web项目的开发难度加大,同时对开发人员的技术要求也提高了。

2.JavaWeb经典三层框架

我们常说的三层框架是由JavaWeb提出的,也就是说这是JavaWeb独有的!

所谓三层是表述层(WEB层)、业务逻辑层(Business Logic),以及数据访问层(Data Access)。

·WEB层:包含JSP和Servlet等与WEB相关的内容;

·业务层:业务层中不包含JavaWeb API,它只关心业务逻辑;

·数据层:封装了对数据库的访问细节;

注意,在业务层中不能出现JavaWeb API,例如request、response等。也就是说,业务层代码是可重用的,甚至可以应用到非Web环境中。业务层的每个方法可以理解成一个万能,例如转账业务方法。业务层依赖数据层,而Web层依赖业务层!

浅谈Javaweb经典三层架构和MVC框架模式

注:网上很多人在讨论MVC究竟是一种框架模式还是一种设计模式(百度百科中强行解释其为一种框架模式而不是一种设计模式),虽然Java中的23种设计模式里并没有MVC,但是我认为讨论这个问题没有太大的必要。我们大可将他作为一种思想,我们需要做的仅仅是理解它,应用它,掌握其中的思想,这才是我们需要做的。

 

责任编辑:武晓燕 来源: 今日头条
相关推荐

2009-04-30 09:15:25

三层结构MVC架构

2009-04-30 15:56:50

三层架构MVCMVP

2009-07-28 15:08:50

MVC三层架构实例

2012-02-07 10:40:13

MVCJava

2009-09-23 17:29:54

三层框架

2012-02-03 09:44:33

.NET

2015-07-02 10:57:11

General框架架构开发

2011-04-19 13:53:41

三层架构

2009-04-21 11:27:52

MVCJSPJDBC

2009-05-06 09:40:04

LINQWEB开发构架

2009-08-26 18:20:42

三层架构

2013-01-09 11:00:20

架构开发三层架构.NET架构

2009-07-28 17:25:14

ASP.NET三层结构

2011-08-08 14:14:03

架构

2016-12-19 11:17:48

架构 MVC

2018-10-31 14:32:53

数据中心网络架构

2018-03-08 15:30:31

超融合架构传统三层架构

2009-07-22 13:24:24

ASP.NET MVC

2018-04-24 08:47:43

超融合HCI数据中心

2018-05-24 11:38:17

点赞
收藏

51CTO技术栈公众号