鍍金池/ 問(wèn)答/Java/ 關(guān)于 DispatcherServlet 和 ContextLoaderList

關(guān)于 DispatcherServlet 和 ContextLoaderListener 的一些疑問(wèn)。

在 Spring MVC 的開(kāi)發(fā)中,會(huì)在 web.xml 中配置 DispatcherServletContextLoaderListener ,對(duì)此有一些疑惑。

我是創(chuàng)建了一個(gè) applicationContext.xmlspring-mvc.xml 文件。

applicationContext.xml 中配置了了 datasource、transcation。
spring-mvc.xml 中配置了開(kāi)啟 annotation 掃描的一些配置。

那么是否應(yīng)該這樣分模塊的進(jìn)行配置,以及我這樣配置是否合理?

再緊接著的又一個(gè)問(wèn)題就是: DispatcherServletContextLoaderListener 都會(huì)加載配置文件。

  • 那么什么樣的配置應(yīng)該在這兩者中的哪一個(gè)上加載?
  • 是否可以不配置 ContextLoaderListener,而全部用 DispatcherServlet 加載?
  • 這兩者加載配置文件又什么區(qū)別?

經(jīng)查詢網(wǎng)上大多都是復(fù)制粘貼一樣的答案,而且含糊不清:

  • DispatcherServlet 一般會(huì)加載 MVC 相關(guān)的 bean 配置管理
  • ContextLoaderListener 一般會(huì)加載整個(gè) Spring 容器相關(guān)的 bean 配置管理

現(xiàn)在我是這樣進(jìn)行配置的:

  <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:spring-mvc.xml</param-value>
    </init-param>
  </servlet>

  <servlet-mapping>
    <servlet-name>SpringMVC</servlet-name>
    <url-pattern>/</url-pattern>
  </servlet-mapping>



  <listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  </listener>
  <context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>
      classpath:applicationContext.xml,
    </param-value>
  </context-param>
回答
編輯回答
離殤

</servlet-mapping>
這個(gè)是前端控制器設(shè)計(jì)模式的實(shí)現(xiàn),提供Spring Web MVC的集中訪問(wèn)點(diǎn),而且負(fù)責(zé)職責(zé)的分派,而且與Spring IoC容器無(wú)縫集成,從而可以獲得Spring的所有好處
DispatcherServlet主要用作職責(zé)調(diào)度工作,本身主要用于控制流程,主要職責(zé)如下:

文件上傳解析,如果請(qǐng)求類型是multipart將通過(guò)MultipartResolver進(jìn)行文件上傳解析;
通過(guò)HandlerMapping,將請(qǐng)求映射到處理器(返回一個(gè)HandlerExecutionChain,它包括一個(gè)處理器、多個(gè)HandlerInterceptor攔截器);
通過(guò)HandlerAdapter支持多種類型的處理器(HandlerExecutionChain中的處理器);
通過(guò)ViewResolver解析邏輯視圖名到具體視圖實(shí)現(xiàn);
本地化解析;
渲染具體的視圖等;
如果執(zhí)行過(guò)程中遇到異常將交給HandlerExceptionResolver來(lái)解析。

load-on-startup:表示啟動(dòng)容器時(shí)初始化該Servlet;如果它存在,則它將在應(yīng)用程序啟動(dòng)時(shí)裝在servlet并調(diào)用它的init方法。若不存在,則在該servlet的第一個(gè)請(qǐng)求時(shí)加載。
url-pattern:表示哪些請(qǐng)求交給Spring Web MVC處理, “/” 是用來(lái)定義默認(rèn)servlet映射的。也可以如“*.html”表示攔截所有以html為擴(kuò)展名的請(qǐng)求。

該DispatcherServlet默認(rèn)使用WebApplicationContext作為上下文,Spring默認(rèn)配置文件為“/WEB-INF/[servlet名字]-servlet.xml”。
<listener>

2017年5月13日 03:25
編輯回答
擱淺

<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:spring-mvc.xml</param-value>
</init-param>

</servlet>
<servlet-mapping>

<servlet-name>SpringMVC</servlet-name>
<url-pattern>/</url-pattern>

</servlet-mapping>
這個(gè)是前端控制器設(shè)計(jì)模式的實(shí)現(xiàn),提供Spring Web MVC的集中訪問(wèn)點(diǎn),而且負(fù)責(zé)職責(zé)的分派,而且與Spring IoC容器無(wú)縫集成,從而可以獲得Spring的所有好處
DispatcherServlet主要用作職責(zé)調(diào)度工作,本身主要用于控制流程,主要職責(zé)如下:

文件上傳解析,如果請(qǐng)求類型是multipart將通過(guò)MultipartResolver進(jìn)行文件上傳解析;
通過(guò)HandlerMapping,將請(qǐng)求映射到處理器(返回一個(gè)HandlerExecutionChain,它包括一個(gè)處理器、多個(gè)HandlerInterceptor攔截器);
通過(guò)HandlerAdapter支持多種類型的處理器(HandlerExecutionChain中的處理器);
通過(guò)ViewResolver解析邏輯視圖名到具體視圖實(shí)現(xiàn);
本地化解析;
渲染具體的視圖等;
如果執(zhí)行過(guò)程中遇到異常將交給HandlerExceptionResolver來(lái)解析。

load-on-startup:表示啟動(dòng)容器時(shí)初始化該Servlet;如果它存在,則它將在應(yīng)用程序啟動(dòng)時(shí)裝在servlet并調(diào)用它的init方法。若不存在,則在該servlet的第一個(gè)請(qǐng)求時(shí)加載。
url-pattern:表示哪些請(qǐng)求交給Spring Web MVC處理, “/” 是用來(lái)定義默認(rèn)servlet映射的。也可以如“*.html”表示攔截所有以html為擴(kuò)展名的請(qǐng)求。

該DispatcherServlet默認(rèn)使用WebApplicationContext作為上下文,Spring默認(rèn)配置文件為“/WEB-INF/[servlet名字]-servlet.xml”。
<listener>

<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>

</listener>
<context-param>

<param-name>contextConfigLocation</param-name>
<param-value>
  classpath:applicationContext.xml,
</param-value>

</context-param>
如上配置是Spring集成Web環(huán)境的通用配置;一般用于加載除Web層的Bean(如DAO、Service等),以便于與其他任何Web框架集成。
contextConfigLocation:表示用于加載Bean的配置文件;
contextClass:表示用于加載Bean的ApplicationContext實(shí)現(xiàn)類,默認(rèn)WebApplicationContext。
創(chuàng)建完畢后會(huì)將該上下文放在ServletContext:

servletContext.setAttribute(
WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE,
this.context);

ContextLoaderListener初始化的上下文和DispatcherServlet初始化的上下文關(guān)系,如圖

clipboard.png

2017年12月15日 09:02
編輯回答
愚念

這個(gè)是spring父子容器的問(wèn)題吧,SpringMVC的spring-mvc.xml負(fù)責(zé)@Controller注解的Bean的注冊(cè),Spring父容器的applicationContext.xml負(fù)責(zé)其他非@Controller注解的Bean的注冊(cè),可以把全部配置陪在子容器里面.如果把全部Bean在父容器注冊(cè),源碼里面會(huì)導(dǎo)致從子容器中取不到注冊(cè)的Controller從而找不到Handler,所以訪問(wèn)controller會(huì)是404.

2017年6月21日 13:05