《经久不衰的Spring框架:SpringMVC 统括》
本文内容纲要:
-前言:经久不衰的Spring
-SpringMVC简介
-SpringMVC与Struts2
-SpringMVC关键部分
-编后语
前言:经久不衰的Spring
这几年,前端技术更新换代速度之快,每一年“最火的前端技术”排行榜都会换一番场景,本当に信じかねる。是“只闻新人笑不见旧人哭”,还是“青山依旧在,几度夕阳红”,这些只有身处浪潮中才能慢慢体会。
跑偏了,赶紧回归正题。难道Java相关技术没有变革?那肯定不是,这边说的只是Java的企业级开发框架这块。记得笔者刚入职那年,就在使用SSH三大框架,时至今日,公司采用的SSM框架,这其中经久不衰的就是Spring了。常见的SSH三大框架,就是Spring、Struts、Hibernate,到后来半ORM框架ibatis出现了,接着改名Mybatis,若将MVC框架替换为SpringMVC,即凑成了SSM框架(笔者目前在用的各框架版本是Spring4.2.6、Hibernate4.3.1、Mybatis3.2.8)。
虽然是本人介绍Spring的第一篇文章,但这几大框架我不用多加介绍了,网上文章多如牛毛,我再描述,那就有点老生常谈的意味了。直接写一些开发工作中,遇到相关卡壳问题和经验总结,纯属记录,毕竟Java当前吃饭的饭碗。
SpringMVC简介
SpringMVC是一种基于Java的实现了WebMVC设计模式的请求驱动类型的轻量级Web框架,即使用了MVC架构模式的思想,将Web层进行职责解耦,基于请求驱动指的就是使用请求-响应模型,框架的目的就是帮助我们简化开发。它和Struts一样是一个MVC框架,它是Spring当中的一个子框架,和Spring无缝集成,和Struts2类似。
SpringMVC的前端控制器是DispatcherServlet;应用控制器其实拆为处理器映射器(HandlerMapping)进行处理器管理和视图解析器(ViewResolver)进行视图管理;页面控制器/动作/处理器为Controller接口(仅包含ModelAndViewhandleRequest(request,response)方法)的实现(也可以是任何的POJO类);支持本地化(Locale)解析、主题(Theme)解析及文件上传等;提供了非常灵活的数据验证、格式化和数据绑定机制;提供了强大的约定大于配置(惯例优先原则)的契约式编程支持。
大概概述下SpringMVC的步骤:
l步骤1——对Http请求进行初步处理,查找与之对应的Controller处理类(方法)——HandlerMapping
l步骤2——调用相应的Controller处理类(方法)完成业务逻辑——HandlerAdapter
l步骤3——对Controller处理类(方法)调用时可能发生的异常进行处理——HandlerExceptionResolver
l步骤4——根据Controller处理类(方法)的调用结果,进行Http响应处理——ViewResolver
使用SpringMVC框架好处:进行更简洁的Web层的开发;天生与Spring框架集成(如IoC容器、AOP等);提供强大的约定大于配置的契约式编程支持;容易与其他视图技术集成;对静态资源的支持;支持Restful风格等等。
SpringMVC与Struts2
**这边并不会去过多得对两大框架进行对比,以免引发两方阵营得争论,只是简单介绍一下Struts2框架,并继续列举认可SpringMVC的理由。
**什么是Struts2?
Struts2是一个基于MVC设计模式的Web应用框架,它本质上相当于一个servlet,在MVC设计模式中,Struts2作为控制器(Controller)来建立模型与视图的数据交互。Struts2是Struts的下一代产品,是在Struts1和WebWork的技术基础上进行了合并的全新的Struts2框架。其全新的Struts2的体系结构与Struts1的体系结构差别巨大。Struts2以WebWork为核心,采用拦截器的机制来处理用户的请求,这样的设计也使得业务逻辑控制器能够与ServletAPI完全脱离开,所以Struts2可以理解为WebWork的更新产品。虽然从Struts1到Struts2有着太大的变化,但是相对于WebWork,Struts2的变化很小。
**为什么是SpringMVC?**
1、相比Struts2,SpringMVC与Spring更加贴合,DispatcherServlet是前端控制器设计模式的实现,提供SpringWebMVC的集中访问点,而且负责职责的分派,而且与SpringIoC容器无缝集成,从而可以获得Spring的所有好处。
2、设计原则更加明朗。这条重要的设计原则被写在了spring官方的reference中SpringMVC章节的起始段:AkeydesignprincipleinSpringWebMVCandinSpringingeneralisthe“Openforextension,closedformodification”principle.并且重点很好地体现在SpringMVC的实现当中,可以扩展,但却不能改变。我曾经扩展过Spring的IOC、AOP功能,这一点SpringMVC应该和Spring一脉相承。
3、组件化的设计方案和特定的设计原则让SpringMVC形散神聚,SpringMVC总是沿着一条固定的逻辑主线运行,却拥有多种不同的行为模式。
SpringMVC关键部分
**废话不多说了,也该讲一些实际一点的东西了。
**一、前端控制器--DispatcherServlet
※所有J2EE项目都是从web.xml启动,阅读或构建一个J2EE项目,都应该先找web.xml开始。
※任何MVC框架都需要一个入口,SpringMVC的入口是在web.xml文件中的核心分发DispatcherServlet;
※DispatcherServlet是前端控制器设计模式的实现,提供SpringWebMVC的集中访问点,而且负责职责的分派,而且与SpringIoC容器无缝集成,从而可以获得Spring的所有好处。DispatcherServlet默认使用WebApplicationContext作为上下文,Spring默认配置文件为/WEB-INF/[servlet名字]-servlet.xml;
<servlet>
<servlet-name>SpringMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath*:mvc-config.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>SpringMVC</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
**二****、**最简注解映射配置
笔者使用的是SpringMVC4.x,不用像SpringMVC3.0时代,配置一大堆的HandlerMapping、HandlerAdapter、Converter。
对,没有错,你仅仅需要配置一句话:mvc:annotation-driven/
mvc:annotation-driven/相当于注册了DefaultAnnotationHandlerMapping和AnnotationMethodHandlerAdapter两个bean,配置一些messageconverter。即解决了@Controller注解的使用前提配置。
**三、**静态资源最优处理
如果你的DispatcherServlet拦截*.do这样的URL,就不存在访问不到静态资源的问题,但是要多书写.do。
如果你的DispatcherServlet拦截“/”,拦截了所有的请求,同时对*.js,*.jpg的访问也就被拦截了。
当然,想要restful风格的话,就必须采用后者,那么就动手来解决一下静态资源问题。
方案一:在Spring3.0.4以后版本提供了mvc:resources
mvc:resources的使用方法:
<mvc:resourceslocation="/images/"mapping="/images/**"/>
<mvc:resourceslocation="/js/"mapping="/js/**"/>
<mvc:resourceslocation="/css/"mapping="/css/**"/>
说明:/images/**映射到ResourceHttpRequestHandler进行处理,location指定静态资源的位置.可以是webapplication根目录下、jar包里面,这样可以把静态资源压缩到jar包中。cache-period可以使得静态资源进行webcache
方案二,使用mvc:default-servlet-handler/
说明:mvc:default-servlet-handler/会把"/**"url,注册到SimpleUrlHandlerMapping的urlMap中,把对静态资源的访问由HandlerMapping转到org.springframework.web.servlet.resource.DefaultServletHttpRequestHandler处理并返回。
DefaultServletHttpRequestHandler使用就是各个Servlet容器自己的默认Servlet。
方案三:激活Tomcat的defaultServlet来处理静态文件
web.xml中书写代码如下:
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.jpg</url-pattern>
<url-pattern>*.gif</url-pattern>
<url-pattern>*.png</url-pattern>
<url-pattern>*.js</url-pattern>
<url-pattern>*.css</url-pattern>
<url-pattern>*.html</url-pattern>
</servlet-mapping>
说明:本人采用这种方式,Tomcat直接处理静态资源效率较高。缺点就是需要配置多个,每种文件配置一个,并且要写在DispatcherServlet的前面,让defaultServlet先拦截。
**四、**视图映射配置
这点没什么好说的,多种配置方式,直接上一种配置代码:
<beanclass="org.springframework.web.servlet.view.InternalResourceViewResolver"p:prefix="/project/"p:suffix=".jsp"/>
**五、**文件上传解析器
SpringMVC实现多文件上传的方式有两种,一种是我们经常使用的以字节流的方式进行文件上传,另外一种是使用SpringMVC包装好的解析器进行上传,这两种方式对于实现多文件上传效率上却有着很大的差距,建议采用后者。
部分配置如下:
<beanid="multipartResolver"class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<propertyname="defaultEncoding"value="utf-8"></property>
<propertyname="maxUploadSize"value="10485760000"></property>
<propertyname="maxInMemorySize"value="40960"></property>
</bean>
说明:这边不是文件上传专栏,不详细介绍。
**六、**控制器扫描
这部分其实应该归纳在Spring部分,但是SpringMVC也是基于Bean去操作的,需要扫描一下控制器Bean。
配置代码如下:
<context:component-scanbase-package="com.demo"use-default-filters="false">
<context:include-filtertype="annotation"expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
说明:这样配置的意思是只扫描com.demo包下@Controller注解标注的类,use-default-filters属性配置为false是必须的。
编后语
SpringMVC可以介绍的功能和内容无论从深度还是广度上,都远远不止本文提到的这些内容,这些只不过是最基础的部分。
SpringMVC为Web开发提供了相当得便捷,但在用的过程中还是要理解它的实现原理和思路,再往深一层来说,它毕竟只是框架,它适合做什么、能够做什么、怎么做,这些都应该由你自己做主,不能被框架左右。
后续的博文会书写Spring相关的一些技术点总结以及经验之谈,敬请关注。
“风萧萧兮易水寒壮士一去兮不复还”
本文内容总结:前言:经久不衰的Spring,SpringMVC简介,SpringMVC与Struts2,SpringMVC关键部分,编后语,
原文链接:https://www.cnblogs.com/shanrengo/p/6403710.html