Spring MVC工做流程圖前端
圖1:
設計模式
圖2:
服務器
Spring工做流程描述架構
1. 用戶向服務器發送請求,請求被Spring 前端控制Servelt DispatcherServlet捕獲;app
2. DispatcherServlet 對請求URL進行解析,獲得請求資源標識符(URI)。而後根據該URI,調用HandlerMapping得到該Handler配置的全部相關的對象 (包括Handler對象以及Handler對象對應的攔截器),最後以HandlerExecutionChain對象的形式返回;spa
3. DispatcherServlet 根據得到的Handler,選擇一個合適的HandlerAdapter。(附註:若是成功得到HandlerAdapter後,此時將開始執行攔截器的preHandler(...)方法)設計
4. 提取Request中的模型數據,填充Handler入參,開始執行Handler(Controller)。 在填充Handler的入參過程當中,根據你的配置,Spring將幫你作一些額外的工做:xml
HttpMessageConveter: 將請求消息(如Json、xml等數據)轉換成一個對象,將對象轉換爲指定的響應信息對象
數據轉換:對請求消息進行數據轉換。如String轉換成Integer、Double等資源
數據根式化:對請求消息進行數據格式化。 如將字符串轉換成格式化數字或格式化日期等
數據驗證: 驗證數據的有效性(長度、格式等),驗證結果存儲到BindingResult或Error中
5. Handler執行完成後,向DispatcherServlet 返回一個ModelAndView對象;
6. 根據返回的ModelAndView,選擇一個適合的ViewResolver(必須是已經註冊到Spring容器中的ViewResolver)返回給DispatcherServlet ;
7. ViewResolver 結合Model和View,來渲染視圖
8. 將渲染結果返回給客戶端。
問題:
爲何SpringMVC只使用一個Servlet(DispatcherServlet)來處理全部請求?
詳細見J2EE設計模式-前端控制模式
SpringMVC爲何要結合使用HandlerMapping以及HandlerAdapter來處理Handler?
符合面向對象中的單一職責原則,代碼架構清晰,便於維護,最重要的是代碼可複用性高。如HandlerAdapter可能會被用於處理多種Handler。