概述
传统的Model1和Model2
在Model1的模式下,整个Web应用几乎全部是由JSP页面组成,接受和处理用户请求,并对请求处理后直接做出响应;JSP身兼View和Controller两个角色,将控制逻辑和表现逻辑糅合在一起。
缺点:
- 代码的复用性低。
- 增加了应用扩展和维护的难度。
Model2是基于MVC架构的设计模式,具体实现如下如:
MVC分层设计.png
MVC的思想是将一个应用分成三个基本部分,模型(Model)、视图(View)、控制器(Controller),这三个部分以最少的耦合协同工作,从而提高应用程序的可扩展性和可维护性。
- 模型(Model):JavaBean
- 视图(View):JSP页面
- 控制器(Controller):Servlet
MVC模式使得Model2具有组件化特点,更能适用于大规模应用的开发(但增加了开发的复杂度)。
MVC优势
MVC并不是Java语言和Web应用特有的设计思想,它是所有面向对象程序设计语言都应该遵守的规范。
在经典的MVC模式中,事件由控制器处理,控制器根据事件的类型改变模型或视图,反之亦然。
MVC的特点:
- 多个视图可以对应一个模型。按MVC的设计模式,一个模型对应多个视图,可以减少代码的复制及代码的维护量。一旦模型发生改变,也易于维护。
- 模型返回的数据与显示逻辑分离。模型数据可以应用任何的显示技术。
- 应用被分为三层,降低了各层之间的耦合,提供了应用的可扩展性。
- 控制层的概念也很有效,由于把不同的模型和不同的视图组合在一起,完成不同的请求。因此,控制层可以说包含了用户请求的权限的概念。
- MVC更符合软件工程化管理的精神。不同的层各司其职,每一层的组件具有相同的特征,这有利于通过工程化和工具化的方法产生管理程序代码。
注:经典MVC思想与Web应用的MVC思想存在一定差别,主要原因是Web应用是一种请求/响应模式。如果用户不对应用发出请求,视图无法主动更新自己。
Spring MVC
Spring框架提供了构建Web应用程序的全功能MVC模块:Spring MVC。
Spring MVC提供了一个DispatcherServlet作为前端控制器来分发请求,同时提供灵活的配置处理程序映射、视图解析、语言环境和主题解析,并支持文件上传。Spring MVC包含多种视图技术,分离了控制器、模型对象、分派器和处理程序对象的角色,使他们更容易进行定制。
Spring MVC特点:
- 具有强大的灵活性、非侵入性、可配置性。
- 提供了前端控制器DispatcherServlet,无需额外开发控制器对象。
- 分工明确,包括控制器、验证器、命令对象、模型对象、处理程序映射视图解析器等,每一个功能实现由一个专门的对象负责完成。
- 可以自动绑定用户输入,并正确转换数据类型。
- 使用一个名称/值得Map对象实现更加灵活的模型数据传输。
- 内置常见的校验器,可以校验用户输入,如果校验不通过,则重定向回输入表单。输入校验可选,支持编程方式和声明方式。
- 支持国际化,支持根据用户区域显示多国语言,并且国际化的配置非常简单。
- 支持多种视图技术。
- 提供简单而强大的JSP标签库,支持数据绑定功能。
Spring MVC的使用
Spring MVC的DispatcherServlet是一个Servlet,继承自HTTPServlet,所以使用时需要配置在Web应用的web.xml文件中:
<servlet>
<!-- Servlet的名称 -->
<servlet-name>springmvc</servlet-name>
<!-- Servlet对应的Java类 -->
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!-- 当前Servlet的参数 -->
<init-param>
<!-- Servlet参数的名称 -->
<param-name>contextConfigLocation</param-name>
<!-- Servlet参数的值:Spring MVC的配置文件路径 -->
<param-value>classpath:springmvc-config.xml</param-value>
</init-param>
<!-- Web应用启动时立即加载Servlet -->
<load-on-startup>1</load-on-startup>
</servlet>
<!-- Servlet的映射声明 -->
<servlet-mapping>
<!-- 请求对应的Servlet的名称 -->
<servlet-name>springmvc</servlet-name>
<!-- 监听当前域的所有请求 -->
<url-pattern>/</url-pattern>
</servlet-mapping>
配置文件中各条配置含义见注释内容,整个文件内容的含义:配置了一个DispatcherServlet,该DispatcherServlet在Web应用启动时立即加载,DispatcherServlet在加载时需要一个Spring MVC的配置文件,默认配置下会到应用程序目录的WEB-INF目录下查找[servlet-name]-servlet.xml文件,即在上面配置中就是查找/WEB-INF/springmvc-servlet.xml。
上面配置是把配置文件命名为springmvc-config.xml,并使用参数元素init-param进行了配置,表示DispatcherServlet会查找应用程序的classpath:springmvc-config.xml文件作为配置文件,进行解析并根据配置文件内容创建一个WebApplicationContext容器对象(上下文环境)。
WebApplicationContext继承自ApplicationContext容器,它的初始化方式和ApplicationContext不同,因为WebApplicationContext需要ServletContext实例,必须拥有Web容器的前提下才能完成启动Spring Web应用上下文的工作。
MVC模式、Spring MVC框架及DispatcherServlet先记录到这里,后面继续Spring MVC的使用记录。
网友评论