1、ContextLoaderListener
从web.xml开始,我们首先通过〈listener〉元素增加了一个ServletContextListener的定义,即org.springframework.web.context. ContextLoaderListener。ContextLoaderListener的职责在于,它将为整个的Web应用程序加载顶层的WebApplicationContext (ROOT WebApplicationContext) 。该顶层WebApplicationContext主要用于提供应用所使用的中间层服务。我们所使用的数据源(DataSource)定义、数据访问对象(DAO)定义、服务对象(Services)定义等,都在该WebApplicationContext中注册。你完全可以将其比作独立运行的应用程序中我们所使用的ClassPathXmlApplicationContext或者FileSystemXmlApplicationContext, 只不过,WebApplicationContext 专门用于Web环境下。
ContextLoaderListener 加载的WebApplicationContext 的默认配置文件路径为/WEB-INF/ applicationContext.xml。实际开发中,不管是出于团队并行开发效率的考虑,还是出于便于管理的因素考虑,很少会使用默认的单一的/WEB-INF/ applicationContext.xml来管理整个Web应用程序的所有中间层服务对象。我们要么会按照应用程序的层次进行配置文件的分割,要么会按照系统功能模块进行配置文件的分割。当存在多个分割后的配置文件的时候,ContextLoaderListener的默认加载行为将成为我们的制约。这时,我们可以通过在web.xml中指定名称为 contextConfigLocation 的配置参数来打破默认行为的制约。
2、DispatcherServlet
DispatcherServlet也使用了一个外部化的配置文件,用来配置Spring MVC框架在处理Web清求过程中所涉及的各个组件,包括HandlerMapping定义、Controller定义、ViewResolver定义等。该外部化的配置文件存在的默认路径也是/WEB-INF/,名称需要参照web.xml中定义的DispatcherServlet的〈servlet-name>来决定。比如,我们当前定义的DispatcherServlet对应的<servlet-name>为springmvc_reset,那么,默认的配置文件即对应/WEB-INF/springmvc_reset-servlet.xml,也就是说,DispatcherServlet对应的默认配置文件名称,将在<servlet-name>的值的基础上后加-servlet.xml.如果我们定义DispatcherServlet 的〈servlet-name〉为simplefx,那么它的配置文件名称就应该为simplefx-servlet .xml,以此类推。
DispatcherServlet启动之后将加载<servlet-nawe>-servlet.xml配置文件,并构建相应的WebApplicationContext。该WebApplicationContext将之前通过ContextLoaderListener 加载的顶层WebApplicat ionContext ( ROOT WebApplicationContext)作为父容器(Parent Applicationcontext) 。这样,如果需要.<servlet-name>-servlet.xml中注册的各种面向Web层的组件,也可以注入来自顶层WebApplicationContext的依赖了。所以,我们也就不难想象出<servlet-name>-servlet. xml 对应的WebApplicationContext 和默认的/WEB-INF/applicationContext.xml 对应的顶层WebApplicationContext之间的逻辑依赖关系了(见下图)。
即使Web层通常很薄,但随着Web应用程序的开发进程,单一的<servlet-name>-servlet, xml文件有可能成为团队并行开发的瓶颈,或者其身材也可能会越加臃肿。出于这些因素考虑,我们需要寻求分割单一的<servlet-name>-servlet.xml文件的解决方法,而DispatcherServlet 的contextConfigLocation初始化参数就是为此而生的。
2.1 HandlerMapping
HandlerMapping帮助DispatcherServlet查找具体的Spring Controller 以处理Web 请求。 如果没有配置任何HandlerMapping的话,Spring MVC也会默认使用BeanNameUrl-HandlerMapping进行URL到具体Controller的匹配。BeanNameUrlHandlerMapping要求相应的Controller的bean定义名称以/开头。
使用<mvc:annotation-driven>启用注解驱动的Spring MVC。
2.2 ViewResover
DispatcherServlet现在需要依赖于某一个org. springf ramework. web. servlet .ViewResolver来帮它处理逻辑视图名与具体的View实例之间的映射对应关系。ViewResolver将根据ModelAndView中的逻辑视图名查找相应的View实现类,然后将查找的结果返回DispatcherServlet。DispatcherServlet最终会将ModelAndView中的模型数据交给返回的View来处理最终的视图渲染工作。
以多种不同的方式来搭建Spring MVC: