前言
SpringMVC 作為 MVC 的開源框架,現在依舊是不少項目使用的重點框架。SpringMVC = Struts2 + Spring,SpringMVC就相當於 Struts2 + Spring 的整合,SpringMVC 是 Spring 的一個后續產品,其實就是在 Spring 的原有基礎上,又提供了 web 應用的 MVC 模塊,可以簡單地把 SpringMVC 理解為是 Spring 的一個子模塊,所以可以和 Spring 進行無縫集成。
1、SpringMVC重要組件
- 前端控制器(DispatcherServlet):接收請求,響應結果,可以理解為電腦的CPU。
- 處理器映射器(HandlerMapping):根據URL去查找處理器。
- 處理器適配器(HandlerAdapter) :它調用后端處理器中的方法,返回邏輯視圖 ModelAndView 對象。
- 處理器(Handler):對用戶具體請求進行處理,也就是程序猿編寫代碼處理邏輯的, 類似於Controller 類。
- 視圖解析器(ViewResovler):進行視圖解析,將 ModelAndView 邏輯視圖解析為具體的視圖(如JSP)。
我把它放在一張圖上,大致位置如下:
2、執行流程
我用箭頭標出對應流程步驟、組件,這樣有助於我們理解、記憶。
通過下圖,我可以得出 SpringMVC 執行流程的大致路線。在配合組件的具體功能,就可以大致總結出 SpringMVC 的執行流程了。
SpringMVC執行流程:
1、用戶發送請求至前端控制器(DisptcherServlet)。
2、 DispatcherServlet 收到請求調用處理器映射器(HandlerMapping)。
3、 處理器映射器找到具體的處理器(可以根據xml配置、注解進行查找),生成處理器對象及處理器攔截器(如果有則生成)一並返回給 DispatcherServlet。
4、 DispatcherServlet 調用處理器適配器(HandlerAdapter)。
5、 HandlerAdapter 經過適配調用具體的處理器(Controller,也叫后端控制器)。
6、 Controller 執行完成返回 ModelAndView。
7、 HandlerAdapter 將 Controller 執行結果 ModelAndView 返回給 DispatcherServlet。
8、 DispatcherServlet 將 ModelAndView 傳給視圖解析器(ViewReslover)。
9、 ViewReslover 解析后返回具體 View。
10、DispatcherServlet 根據 View 進行渲染視圖(即將模型數據填充至視圖中)。
11、 DispatcherServlet 響應用戶。
3、SpringMVC組件功能介紹
1、前端控制器DispatcherServlet(不需要工程師開發),由框架提供
作用:接收請求,響應結果,相當於轉發器,中央處理器。有了dispatcherServlet減少了其它組件之間的耦合度。
用戶請求到達前端控制器,它就相當於mvc模式中的c,dispatcherServlet是整個流程控制的中心,由它調用其它組件處理用戶的請求,dispatcherServlet的存在降低了組件之間的耦合性。
2、處理器映射器HandlerMapping(不需要工程師開發),由框架提供
作用:根據請求的url查找Handler
HandlerMapping負責根據用戶請求找到Handler即處理器,springmvc提供了不同的映射器實現不同的映射方式,例如:配置文件方式,實現接口方式,注解方式等。
3、處理器適配器HandlerAdapter
作用:按照特定規則(HandlerAdapter要求的規則)去執行Handler
通過HandlerAdapter對處理器進行執行,這是適配器模式的應用,通過擴展適配器可以對更多類型的處理器進行執行。
4、處理器Handler(需要工程師開發)
注意:編寫Handler時按照HandlerAdapter的要求去做,這樣適配器才可以去正確執行Handler
Handler 是繼DispatcherServlet前端控制器的后端控制器,在DispatcherServlet的控制下Handler對具體的用戶請求進行處理。由於Handler涉及到具體的用戶業務請求,所以一般情況需要工程師根據業務需求開發Handler。
5、視圖解析器View resolver(不需要工程師開發),由框架提供
作用:進行視圖解析,根據邏輯視圖名解析成真正的視圖(view)
View Resolver負責將處理結果生成View視圖,View Resolver首先根據邏輯視圖名解析成物理視圖名即具體的頁面地址,再生成View視圖對象,最后對View進行渲染將處理結果通過頁面展示給用戶。springmvc框架提供了很多的View視圖類型,包括:jstlView、freemarkerView、pdfView等。
一般情況下需要通過頁面標簽或頁面模版技術將模型數據通過頁面展示給用戶,需要由工程師根據業務需求開發具體的頁面。
6、視圖View(需要工程師開發jsp...)
View 是一個接口,實現類支持不同的View類型(jsp、freemarker、pdf...)
4、核心架構的具體流程
核心架構的具體流程步驟如下:
1、首先用戶發送請求——>DispatcherServlet,前端控制器收到請求后自己不進行處理,而是委托給其他的解析器進行處理,作為統一訪問點,進行全局的流程控制;
2、DispatcherServlet——>HandlerMapping, HandlerMapping 將會把請求映射為HandlerExecutionChain 對象(包含一個Handler 處理器(頁面控制器)對象、多個HandlerInterceptor 攔截器)對象,通過這種策略模式,很容易添加新的映射策略;
3、DispatcherServlet——>HandlerAdapter,HandlerAdapter 將會把處理器包裝為適配器,從而支持多種類型的處理器,即適配器設計模式的應用,從而很容易支持很多類型的處理器;
4、HandlerAdapter——>處理器功能處理方法的調用,HandlerAdapter 將會根據適配的結果調用真正的處理器的功能處理方法,完成功能處理;並返回一個ModelAndView 對象(包含模型數據、邏輯視圖名);
5、ModelAndView的邏輯視圖名——> ViewResolver, ViewResolver 將把邏輯視圖名解析為具體的View,通過這種策略模式,很容易更換其他視圖技術;
6、View——>渲染,View會根據傳進來的Model模型數據進行渲染,此處的Model實際是一個Map數據結構,因此很容易支持其他視圖技術;
7、返回控制權給DispatcherServlet,由DispatcherServlet返回響應給用戶,到此一個流程結束。
小結
雖然現在市場的主流是微服務框架,但是 SpringMVC 作為 Spring 家族成員之一,且幾年前得到廣泛應用,現在依舊有不少的老項目在使用這個框架,所以,作為程序猿的我們,也是必須要掌握的一個框架。