`
jinnianshilongnian
  • 浏览: 21508130 次
  • 性别: Icon_minigender_1
博客专栏
5c8dac6a-21dc-3466-8abb-057664ab39c7
跟我学spring3
浏览量:2419366
D659df3e-4ad7-3b12-8b9a-1e94abd75ac3
Spring杂谈
浏览量:3009338
43989fe4-8b6b-3109-aaec-379d27dd4090
跟开涛学SpringMVC...
浏览量:5639911
1df97887-a9e1-3328-b6da-091f51f886a1
Servlet3.1规范翻...
浏览量:260066
4f347843-a078-36c1-977f-797c7fc123fc
springmvc杂谈
浏览量:1597567
22722232-95c1-34f2-b8e1-d059493d3d98
hibernate杂谈
浏览量:250292
45b32b6f-7468-3077-be40-00a5853c9a48
跟我学Shiro
浏览量:5859635
Group-logo
跟我学Nginx+Lua开...
浏览量:702520
5041f67a-12b2-30ba-814d-b55f466529d5
亿级流量网站架构核心技术
浏览量:785431
社区版块
存档分类
最新评论

第一章 Web MVC简介 —— 跟开涛学SpringMVC

阅读更多

Web MVC简介

1.1、Web开发中的请求-响应模型:

 

在Web世界里,具体步骤如下:

1、  Web浏览器(如IE)发起请求,如访问http://sishuok.com

2、  Web服务器(如Tomcat)接收请求,处理请求(比如用户新增,则将把用户保存一下),最后产生响应(一般为html)。

3、web服务器处理完成后,返回内容给web客户端(一般就是我们的浏览器),客户端对接收的内容进行处理(如web浏览器将会对接收到的html内容进行渲染以展示给客户)。

 

因此,在Web世界里:

都是Web客户端发起请求,Web服务器接收、处理并产生响应。

 

一般Web服务器是不能主动通知Web客户端更新内容。虽然现在有些技术如服务器推(如Comet)、还有现在的HTML5 websocket可以实现Web服务器主动通知Web客户端。

 

到此我们了解了在web开发时的请求/响应模型,接下来我们看一下标准的MVC模型是什么。

 

1.2、标准MVC模型概述

MVC模型:是一种架构型的模式,本身不引入新功能,只是帮助我们将开发的结构组织的更加合理,使展示与模型分离、流程控制逻辑、业务逻辑调用与展示逻辑分离。如图1-2

 

图1-2

首先让我们了解下MVC(Model-View-Controller)三元组的概念:

Model(模型):数据模型,提供要展示的数据,因此包含数据和行为,可以认为是领域模型或JavaBean组件(包含数据和行为),不过现在一般都分离开来:Value Object(数据) 和 服务层(行为)。也就是模型提供了模型数据查询和模型数据的状态更新等功能,包括数据和业务。

 

View(视图):负责进行模型的展示,一般就是我们见到的用户界面,客户想看到的东西。

 

Controller(控制器):接收用户请求,委托给模型进行处理(状态改变),处理完毕后把返回的模型数据返回给视图,由视图负责展示。 也就是说控制器做了个调度员的工作,。

 

从图1-1我们还看到,在标准的MVC中模型能主动推数据给视图进行更新(观察者设计模式,在模型上注册视图,当模型更新时自动更新视图),但在Web开发中模型是无法主动推给视图(无法主动更新用户界面),因为在Web开发是请求-响应模型。

 

那接下来我们看一下在Web里MVC是什么样子,我们称其为 Web MVC 来区别标准的MVC。

1.3、Web MVC概述

模型-视图-控制器概念和标准MVC概念一样,请参考1.2,我们再看一下Web MVC标准架构,如图1-3:

 

如图1-3

 

在Web MVC模式下,模型无法主动推数据给视图,如果用户想要视图更新,需要再发送一次请求(即请求-响应模型)。

 

概念差不多了,我们接下来了解下Web端开发的发展历程,和使用代码来演示一下Web MVC是如何实现的,还有为什么要使用MVC这个模式呢?

 

1.4、Web端开发发展历程

此处我们只是简单的叙述比较核心的历程,如图1-4

 

图1-4

1.4.1、CGI:(Common Gateway Interface)公共网关接口,一种在web服务端使用的脚本技术,使用C或Perl语言编写,用于接收web用户请求并处理,最后动态产生响应给用户,但每次请求将产生一个进程,重量级。

 

1.4.2、Servlet:一种JavaEE web组件技术,是一种在服务器端执行的web组件,用于接收web用户请求并处理,最后动态产生响应给用户。但每次请求只产生一个线程(而且有线程池),轻量级。而且能利用许多JavaEE技术(如JDBC等)。本质就是在java代码里面 输出 html流。但表现逻辑、控制逻辑、业务逻辑调用混杂。如图1-5    

 

图1-5

如图1-5,这种做法是绝对不可取的,控制逻辑、表现代码、业务逻辑对象调用混杂在一起,最大的问题是直接在Java代码里面输出Html,这样前端开发人员无法进行页面风格等的设计与修改,即使修改也是很麻烦,因此实际项目这种做法不可取。

 

1.4.3、JSP(Java Server Page):一种在服务器端执行的web组件,是一种运行在标准的HTML页面中嵌入脚本语言(现在只支持Java)的模板页面技术。本质就是在html代码中嵌入java代码。JSP最终还是会被编译为Servlet,只不过比纯Servlet开发页面更简单、方便。但表现逻辑、控制逻辑、业务逻辑调用还是混杂。如图1-6

 

 

图1-6

 

如图1-6,这种做法也是绝对不可取的,控制逻辑、表现代码、业务逻辑对象调用混杂在一起,但比直接在servlet里输出html要好一点,前端开发人员可以进行简单的页面风格等的设计与修改(但如果嵌入的java脚本太多也是很难修改的),因此实际项目这种做法不可取。

 

JSP本质还是Servlet,最终在运行时会生成一个Servlet(如tomcat,将在tomcat\work\Catalina\web应用名\org\apache\jsp下生成),但这种使得写html简单点,但仍是控制逻辑、表现代码、业务逻辑对象调用混杂在一起。

 

1.4.4、Model1可以认为是JSP的增强版,可以认为是jsp+javabean如图1-7

特点:使用<jsp:useBean>标准动作,自动将请求参数封装为JavaBean组件;还必须使用java脚本执行控制逻辑。

 

 

图1-7

此处我们可以看出,使用<jsp:useBean>标准动作可以简化javabean的获取/创建,及将请求参数封装到javabean,再看一下Model1架构,如图1-8。

 

图1-8 Model1架构

Model1架构中,JSP负责控制逻辑、表现逻辑、业务对象(javabean)的调用,只是比纯JSP简化了获取请求参数和封装请求参数。同样是不好的,在项目中应该严禁使用(或最多再demo里使用)。

 

1.4.5、Model2在JavaEE世界里,它可以认为就是Web MVC模型

Model2架构其实可以认为就是我们所说的Web MVC模型,只是控制器采用Servlet、模型采用JavaBean、视图采用JSP,如图1-9

 

图1-9 Model2架构

 

具体代码事例如下:

 

 

从Model2架构可以看出,视图和模型分离了,控制逻辑和展示逻辑分离了。

但我们也看到严重的缺点:

1.  1、控制器:

1.1.1、控制逻辑可能比较复杂,其实我们可以按照规约,如请求参数submitFlag=toAdd,我们其实可以直接调用toAdd方法,来简化控制逻辑;而且每个模块基本需要一个控制器,造成控制逻辑可能很复杂;

1.1.2、请求参数到模型的封装比较麻烦,如果能交给框架来做这件事情,我们可以从中得到解放;

1.1.3、选择下一个视图,严重依赖Servlet API,这样很难或基本不可能更换视图;

1.1.4、给视图传输要展示的模型数据,使用Servlet API,更换视图技术也要一起更换,很麻烦。

 

1.2、模型:

1.2.1、此处模型使用JavaBean,可能造成JavaBean组件类很庞大,一般现在项目都是采用三层架构,而不采用JavaBean。

 

 

1.3、视图

1.3.1、现在被绑定在JSP,很难更换视图,比如Velocity、FreeMarker;比如我要支持Excel、PDF视图等等。

 

1.4.5、服务到工作者:Front Controller + Application Controller + Page Controller + Context

即,前端控制器+应用控制器+页面控制器(也有称其为动作)+上下文,也是Web MVC,只是责任更加明确,详情请参考《核心J2EE设计模式》和《企业应用架构模式》如图1-10:

 

图1-10

运行流程如下:

 

职责:

Front Controller前端控制器,负责为表现层提供统一访问点,从而避免Model2中出现的重复的控制逻辑(由前端控制器统一回调相应的功能方法,如前边的根据submitFlag=login转调login方法);并且可以为多个请求提供共用的逻辑(如准备上下文等等),将选择具体视图和具体的功能处理(如login里边封装请求参数到模型,并调用业务逻辑对象)分离。

 

Application Controller应用控制器,前端控制器分离选择具体视图和具体的功能处理之后,需要有人来管理,应用控制器就是用来选择具体视图技术(视图的管理)和具体的功能处理(页面控制器/命令对象/动作管理),一种策略设计模式的应用,可以很容易的切换视图/页面控制器,相互不产生影响。

 

Page Controller(Command)页面控制器/动作/处理器:功能处理代码,收集参数、封装参数到模型,转调业务对象处理模型,返回逻辑视图名交给前端控制器(和具体的视图技术解耦),由前端控制器委托给应用控制器选择具体的视图来展示,可以是命令设计模式的实现。页面控制器也被称为处理器或动作。

 

Context上下文,还记得Model2中为视图准备要展示的模型数据吗,我们直接放在request中(Servlet API相关),有了上下文之后,我们就可以将相关数据放置在上下文,从而与协议无关(如Servlet API)的访问/设置模型数据,一般通过ThreadLocal模式实现。

 

 

到此,我们回顾了整个web开发架构的发展历程,可能不同的web层框架在细节处理方面不同,但的目的是一样的:

干净的web表现层:

    模型和视图的分离;

控制器中的控制逻辑与功能处理分离(收集并封装参数到模型对象、业务对象调用);

控制器中的视图选择与具体视图技术分离。

轻薄的web表现层:

    做的事情越少越好,薄薄的,不应该包含无关代码;

       只负责收集并组织参数到模型对象,启动业务对象的调用;

       控制器只返回逻辑视图名并由相应的应用控制器来选择具体使用的视图策略;

       尽量少使用框架特定API,保证容易测试。

 

到此我们了解Web MVC的发展历程,接下来让我们了解下Spring MVC到底是什么、架构及来个HelloWorld了解下具体怎么使用吧。

 

本章具体代码请参考 springmvc-chapter1工程。

 

 

私塾在线学习网原创内容(http://sishuok.com

原创内容,转载请注明私塾在线【http://sishuok.com/forum/blogPost/list/5050.html

278
13
分享到:
评论
61 楼 JavaStudyEye 2014-06-20  
真心的太棒了,好详细,来龙去脉都写的好,必须支持
60 楼 mmzzy20130214 2014-05-30  
59 楼 ljf_home 2014-05-27  
阿弥陀佛!!!
58 楼 liucm666 2014-03-10  
感谢啊 博主
57 楼 alston_king 2014-02-13  
LZ 你真是好人!!!!大爱!!!!
56 楼 acm365 2013-12-24  
太棒了博主,爱死你了
55 楼 神当当 2013-10-18  
  :lol                                   [code="[list]
[*]

[/list]java"]
54 楼 lanyuaa 2013-09-17  
不错,谢谢你的分享
53 楼 chengangjava 2013-07-26  

还不错,你基本功扎实,可以看出你学习了东西也是很善于分析和总结的.不错.
52 楼 jinnianshilongnian 2013-05-18  
新生无产者 写道
好教程,受益匪浅啊

谢谢
51 楼 新生无产者 2013-05-18  
好教程,受益匪浅啊
50 楼 jinnianshilongnian 2013-05-14  
ydsakyclguozi 写道
请教下开涛老师,您分析的是什么版本的源码?


spring-framework-3.1.1.
49 楼 ydsakyclguozi 2013-05-14  
请教下开涛老师,您分析的是什么版本的源码?
48 楼 gllfeixiang 2013-03-21  
做网站半年了,主要用的就是spring+hibernate,正想学习一下从0开始搭建个网站,学习中,
47 楼 javaEE_dev 2013-03-20  
    
46 楼 =寂寞_狐狸= 2013-03-07  
鼓个掌!
45 楼 Dream.V 2013-01-24  
不错,赞一个!
44 楼 shaweifeng 2013-01-23  
确实不错!赞一个!
43 楼 WODE890502 2013-01-12  
哇塞  分析得好透彻   顶
42 楼 zhujintaozhu 2013-01-09  
好厉害!学习了!

相关推荐

    跟着开涛学SpringMVC

    SpringMVC是一种基于Java实现MVC设计模型的请求驱动类型的轻量级Web框架,它通过分离业务逻辑和表现层来提高应用开发的灵活性和可维护性。 #### WebMVC简介 WebMVC是Web开发中的模型-视图-控制器架构模式。在Web...

    跟着开涛学SpringMVC.pdf

    本教程以开涛的讲解方式,详细阐述了SpringMVC的基本概念、架构以及在Web开发中的应用。 首先,在Web开发中,请求-响应模型是核心交互方式,Web客户端(通常是浏览器)发起请求,Web服务器(例如Tomcat)接收并处理...

    跟开涛学springmvc

    综上所述,《跟开涛学SpringMVC》不仅是一本介绍SpringMVC框架的书,还深入讲解了Web开发原理以及如何合理地利用MVC设计模式来组织Web应用。这本书适合那些希望系统学习Web开发和SpringMVC框架的初学者,以及对Web...

    跟开涛学SpringMVC

    ### 跟开涛学SpringMVC #### 第一章 WebMVC简介 ##### 1.1 Web开发中的请求-响应模型 在Web开发的世界中,客户端与服务器之间的交互遵循着一套基本的请求-响应模型。这个过程可以分为三个主要阶段: 1. **客户端...

    跟开涛学 SpringMVC

    标题《跟开涛学 SpringMVC》和描述《跟开涛学 SpringMVC》表明,本知识点主要围绕SpringMVC的教程展开,本教程由开涛主讲。SpringMVC是Java语言开发中一个非常流行的轻量级Web框架,它遵循了MVC(Model-View-...

    源代码下载 第五章 处理器拦截器详解——跟着开涛学SpringMVC

    通过阅读《跟着开涛学SpringMVC》的相关章节,你可以更详细地了解如何设置和使用处理器拦截器,以及它们在实际项目中的应用。博客链接(https://jinnianshilongnian.iteye.com/blog/1679570)提供了更多实践案例和...

    跟开涛学SpringMVC源代码

    《跟开涛学SpringMVC源代码》是一个深入学习SpringMVC框架的资源集合,它涵盖了从基础到高级的多个章节,旨在帮助开发者全面理解SpringMVC的工作原理和实现细节。SpringMVC作为Spring框架的重要组成部分,是企业级...

    跟开涛学SpringMVC-高清版

    《跟开涛学SpringMVC》是一本深受开发者欢迎的学习资料,主要针对SpringMVC这一强大的Web开发框架进行深入浅出的讲解。SpringMVC是Spring框架的重要组成部分,它为Java开发者提供了构建高性能、可测试的Web应用程序...

    跟开涛学SpringMVC(Alin书签).pdf

    SpringMVC是Spring框架的一部分,它是一个实现MVC设计模式的Web框架。它不仅支持模型、视图和控制器的分离,还支持依赖注入,使得控制器可以轻量级地处理请求。SpringMVC能够将请求映射到控制器方法,并允许使用各种...

    SpringMvc开涛.rar

    PDF,源代码 开涛学SpringMVC 第一章源代码下载 第二章 Spring MVC入门 源代码下载 ...第五章 处理器拦截器详解——跟着开涛学SpringMVC 第六章 注解式控制器详解 第七章 注解式控制器的数据验证、类型转换及格式化

    跟开涛学习springmvc spring 3 pdf

    《跟开涛学习SpringMVC Spring 3》是一份深入浅出的教程,旨在帮助开发者全面理解并掌握SpringMVC和Spring 3的核心概念和技术。这份资料将原本分散的文档整合为两部分,分别是《跟开涛学习spring(1-13).pdf》和《跟...

    跟开涛学 SpringMVC.pdf

    《跟开涛学SpringMVC》是一份开源电子书,通过具体的实例和深入的解释,引导开发者学习和理解SpringMVC。这本书详细讲解了SpringMVC的工作原理和使用方法,对于想要快速掌握SpringMVC的初学者和开发者来说,是一个...

    跟开涛学SpringMVC(7.2)SpringMVC数据

    在本课程"跟开涛学SpringMVC(7.2)SpringMVC数据"中,我们将深入探讨Spring MVC框架在处理数据方面的核心概念和技术。Spring MVC是Spring框架的一部分,专门用于构建Web应用程序,特别是用于处理HTTP请求和响应。在...

    跟开涛学SpringMVC、Spring3

    在"跟开涛学SpringMVC、Spring3"这个教程中,我们可以期待学习到Spring框架的基础知识以及SpringMVC的工作原理。 Spring3是Spring框架的一个版本,发布于2009年,引入了许多新特性和改进。这个教程可能涵盖了以下...

    跟开涛学SpringMVC(6.3)SpringMVC3

    《跟开涛学SpringMVC(6.3)SpringMVC3》是针对SpringMVC框架的一个学习资源,尤其关注其3.1版本的新特性。SpringMVC是Spring框架的重要组成部分,专门用于处理Web应用程序的请求和响应。在这个版本中,SpringMVC...

    跟开涛学SpringMVC(6.2)SpringMVC3强

    在"跟开涛学SpringMVC(6.2)SpringMVC3强"的学习资料中,我们将会深入探讨SpringMVC 3版本中的强大请求映射规则。这个教程共13页,旨在帮助Java开发者掌握SpringMVC的核心特性,提升开发效率和代码质量。 1. **...

Global site tag (gtag.js) - Google Analytics