核心类与接口: css
先来了解一下,几个重要的接口与类。如今不知道他们是干什么的不要紧,先混个脸熟,为之后认识他们打个基础。 web
DispatcherServlet -- 前置控制器 spring
HandlerMapping接口 -- 处理请求的映射 mvc
HandlerMapping接口的实现类: app
SimpleUrlHandlerMapping 经过配置文件,把一个URL映射到Controller 框架
DefaultAnnotationHandlerMapping 经过注解,把一个URL映射到Controller类上 jsp
HandlerAdapter接口 -- 处理请求的映射 url
AnnotationMethodHandlerAdapter类,经过注解,把一个URL映射到Controller类的方法上 spa
Controller接口 -- 控制器 orm
因为咱们使用了@Controller注解,添加了@Controller注解注解的类就能够担任控制器(Action)的职责,
因此咱们并无用到这个接口。
HandlerInterceptor 接口--拦截器
无图,咱们本身实现这个接口,来完成拦截的器的工做。
ViewResolver接口的实现类
UrlBasedViewResolver类 经过配置文件,把一个视图名交给到一个View来处理
InternalResourceViewResolver类,比上面的类,加入了JSTL的支持
View接口
JstlView类
LocalResolver接口
HandlerExceptionResolver接口 --异常处理
SimpleMappingExceptionResolver实现类
ModelAndView类
无图。
DispatcherServlet说明
使用Spring MVC,配置DispatcherServlet是第一步。
DispatcherServlet是一个Servlet,因此能够配置多个DispatcherServlet。
DispatcherServlet是前置控制器,配置在web.xml文件中的。拦截匹配的请求,Servlet拦截匹配规则要自已定义,把拦截下来的请求,依据某某规则分发到目标Controller(咱们写的Action)来处理。
“某某规则”:是根据你使用了哪一个HandlerMapping接口的实现类的不一样而不一样。
先来看第一个例子:
<load-on-startup>1</load-on-startup>是启动顺序,让这个Servlet随Servletp容器一块儿启动。
<url-pattern>*.form</url-pattern> 会拦截*.form结尾的请求。
<servlet-name>example</servlet-name>这个Servlet的名字是example,能够有多个DispatcherServlet,是经过名字来区分的。每个DispatcherServlet有本身的WebApplicationContext上下文对象。同时保存的ServletContext中和Request对象中,关于key,之后说明。
在DispatcherServlet的初始化过程当中,框架会在web应用的 WEB-INF文件夹下寻找名为[servlet-name]-servlet.xml 的配置文件,生成文件中定义的bean。
第二个例子:
指明了配置文件的文件名,不使用默认配置文件名,而使用springMVC.xml配置文件。
其中<param-value>**.xml</param-value> 这里可使用多种写法
一、不写,使用默认值:/WEB-INF/<servlet-name>-servlet.xml
二、<param-value>/WEB-INF/classes/springMVC.xml</param-value>
三、<param-value>classpath*:springMVC-mvc.xml</param-value>
四、多个值用逗号分隔
Servlet拦截匹配规则能够自已定义,拦截哪一种URL合适?
当映射为@RequestMapping("/user/add")时,为例:
一、拦截*.do、*.htm, 例如:/user/add.do
这是最传统的方式,最简单也最实用。不会致使静态文件(jpg,js,css)被拦截。
二、拦截/,例如:/user/add
能够实现如今很流行的REST风格。不少互联网类型的应用很喜欢这种风格的URL。
弊端:会致使静态文件(jpg,js,css)被拦截后不能正常显示。想实现REST风格,事情就是麻烦一些。后面有解决办法还算简单。
三、拦截/*,这是一个错误的方式,请求能够走到Action中,但转到jsp时再次被拦截,不能访问到jsp。