springMvc運行機制

1、 html

spring的啓動過程:前端

1.首先,對於一個web應用,其部署在web容器中,web容器提供其一個全局的上下文環境,這個上下文就是ServletContext,其爲後面的spring IoC容器提供宿主環境;web

2.其 次,在web.xml中會提供有contextLoaderListener。在web容器啓動時,會觸發容器初始化事件,此時 contextLoaderListener會監聽到這個事件,其contextInitialized方法會被調用,在這個方法中,spring會初始 化一個啓動上下文,這個上下文被稱爲根上下文,即WebApplicationContext,這是一個接口類,確切的說,其實際的實現類是 XmlWebApplicationContext。這個就是spring的IoC容器,其對應的Bean定義的配置由web.xml中的 context-param標籤指定。在這個IoC容器初始化完畢後,spring以WebApplicationContext.ROOTWEBAPPLICATIONCONTEXTATTRIBUTE爲屬性Key,將其存儲到ServletContext中,便於獲取;spring

3.再 次,contextLoaderListener監聽器初始化完畢後,開始初始化web.xml中配置的Servlet,這裏是DispatcherServlet,這個servlet其實是一個標準的前端控制器,用以轉發、匹配、處理每一個servlet請 求。DispatcherServlet上下文在初始化的時候會創建本身的IoC上下文,用以持有spring mvc相關的bean。在創建DispatcherServlet本身的IoC上下文時,會利用WebApplicationContext.ROOTWEBAPPLICATIONCONTEXTATTRIBUTE 先從ServletContext中獲取以前的根上下文(即WebApplicationContext)做爲本身上下文的parent上下文。有了這個 parent上下文以後,再初始化本身持有的上下文。這個DispatcherServlet初始化本身上下文的工做在其initStrategies方 法中能夠看到,大概的工做就是初始化處理器映射、視圖解析等。這個servlet本身持有的上下文默認實現類也是 mlWebApplicationContext。初始化完畢後,spring以與servlet的名字相關(此處不是簡單的以servlet名爲 Key,而是經過一些轉換,具體可自行查看源碼)的屬性爲屬性Key,也將其存到ServletContext中,以便後續使用。這樣每一個servlet 就持有本身的上下文,即擁有本身獨立的bean空間,同時各個servlet共享相同的bean,即根上下文(第2步中初始化的上下文)定義的那些 bean。mvc

 

 

2、DispatcherServlet 處理流程app

在整個 Spring MVC 框架中,DispatcherServlet 處於核心位置,它負責協調和組織不一樣組件完成請求處理並返回響應工做。在看 DispatcherServlet 類以前,咱們先來看一下請求處理的大體流程:框架

  1. Tomcat 啓動,對 DispatcherServlet 進行實例化,而後調用它的 init() 方法進行初始化,在這個初始化過程當中完成了:
  2. 對 web.xml 中初始化參數的加載;創建 WebApplicationContext (SpringMVC的IOC容器);進行組件的初始化;
  3. 客戶端發出請求,由 Tomcat 接收到這個請求,若是匹配 DispatcherServlet 在 web.xml 中配置的映射路徑,Tomcat 就將請求轉交給 DispatcherServlet 處理;
  4. DispatcherServlet 從容器中取出全部 HandlerMapping 實例(每一個實例對應一個 HandlerMapping 接口的實現類)並遍歷,每一個 HandlerMapping 會根據請求信息,經過本身實現類中的方式去找處處理該請求的 Handler (執行程序,如Controller中的方法),而且將這個 Handler 與一堆 HandlerInterceptor (攔截器) 封裝成一個 HandlerExecutionChain 對象,一旦有一個 HandlerMapping 能夠找到 Handler 則退出循環;(詳情能夠看 [Java]SpringMVC工做原理之二:HandlerMapping和HandlerAdpater 這篇文章)
  5. DispatcherServlet 取出 HandlerAdapter 組件,根據已經找到的 Handler,再從全部 HandlerAdapter 中找到能夠處理該 Handler 的 HandlerAdapter 對象;
  6. 執行 HandlerExecutionChain 中全部攔截器的 preHandler() 方法,而後再利用 HandlerAdapter 執行 Handler ,執行完成獲得 ModelAndView,再依次調用攔截器的 postHandler() 方法;
  7. 利用 ViewResolver 將 ModelAndView 或是 Exception(可解析成 ModelAndView)解析成 View,而後 View 會調用 render() 方法再根據 ModelAndView 中的數據渲染出頁面;
  8. 最後再依次調用攔截器的 afterCompletion() 方法,這一次請求就結束了

http://www.cnblogs.com/tengyunhao/p/7518481.htmlpost

相關文章
相關標籤/搜索