對JAVA程序員來講,做web開發最熟悉的框架莫過于SpringMVC了。之所以它能一統江湖,不是自己太優秀,而是對手太坑了,不知道大家還記不記得2017年左右Struts2爆出了一個大漏洞,自此之后,Web開發領域的就是SpringMVC的天下了。
但是鑒于這么優秀的框架,很多程序員還只是停留在會用的狀態,對底層的原理卻不甚了解,所以今天咱么就來聊聊SpringMVC的工作原理。
三層架構
在開始介紹SpringMVC之前,咱么要先來了解一下web開發的歷史。我們的開發架構一般都是基于兩種形式,一種是C/S架構,也就是客戶端/服務器,另一種是B/S架構,也就是瀏覽器/服務器。而在JavaWeb開發中,幾乎都是采用B/S架構的開發模式,在這種架構模式中,將整個業務應用劃分為三層架構,分別是::表現層(UI)、業務邏輯層(BLL)、數據訪問層(DAL),核心的思想就是“高內聚,低耦合”。

- 表現層(UI)也就是我們常說的web層,展現給用戶的界面,即用戶在使用一個系統的時候的所見所得。講人話就是我們看到的網頁。
- 業務邏輯層(BLL)也就是我們常說的 service 層。主要對業務業務邏輯處理。
- 數據訪問層(DAL)也就是我們是常說的DAO 層。就是直接操作數據庫,針對數據的增添、刪除、修改、更新、查找等。

MVC框架模式
MVC全稱是【ModelView Controller】,模型(Model)是-視圖(View)-控制器(Controller)的縮寫,是一種軟件設計模式,是一種架構思想,體現的是責任分離思想,各自做各自最擅長的事情。它是基于表現層把程序分為三大部分:模型、視圖、控制器,每一部分又有其單獨的意含義。
- 模型(Model ):數據模型,Model是數據模型,其實就是JavaBean對象,細分可以表示為業務組件(service)、領域模型組件(domain)等,Model包含要展示的數據和擁有的業務功能方法。
- 視圖(View ):數據展示,說人話就是用戶能看到的網頁界面,當然該界面上還需要展示數據模型中的具體數據。
- 控制器(Controller):接收用戶請求,并分發給對應的模型進行處理處理完畢后把返回的模型數據返回給視圖進行渲染,最終展示給用戶。
SpringMVC 的概念
SpringMVC 是一種基于Java 的實現 MVC 設計模型的請求驅動類型的輕量級Web 框架,是Spring 框架提供的構建Web 應用程序的全功能 MVC模塊。目前SpringMVC 已經成為目前最優秀的MVC 框架之一。特別是支持RESTful編程風格,更是和微服架構的無縫契合。

SpringMVC的核心組件
1.DispatcherServlet【前端控制器】
相當于中央處理器,用來分發請求的不同的處理流程,如:分發到HandlerMApping、HandlerAdapter、View resolver等。
2.Controller【處理器】
處理不同類型的業務請求,如:增刪改查的業務。
3.HandlerMapping【處理器映射器】
根據用戶請求找到Handler即處理器,SpringMvc提供了不同的映射器實現不同的映射方式,如:配置文件方式,實現接口方式,注解方式。
4.HandlerAdapter【處理器適配器】
通過HandlerAdapter對處理器進行執行,這是適配器模式的應用,通過擴展適配器可以對更多類型的處理器進行執行。

5.View resolver【視圖解析器】
進行視圖解析,根據邏輯視圖名解析成真正的視圖View視圖,最終需要通過網頁將數據模型展示給用戶。
執行流程
下面我們來通過一張SpringMVC的流程圖,來看一下它的每個組件都是用來的干啥的,有什么作用,明白了這些之后,以后開發的時候就可以很清楚的知道一個請求過來之后,都經過了哪些組件,每一個組件都發揮了什么樣的作用。
根據這張流程圖,我們再來分別解釋一下每一步以及每一個組件的具體作用。
- 用戶發送請求至前端控制器DispatcherServlet,進行分發處理。
- DispatcherServlet收到請求調用處理器映射器HandlerMapping。
- 處理器映射器根據請求url找到具體的處理器,生成處理器執行鏈HandlerExecutionChain(包括處理器對象和處理器攔截器)一并返回給DispatcherServlet。
- DispatcherServlet根據處理器Handler獲取處理器適配器HandlerAdapter執行HandlerAdapter處理一系列的操作,如:參數封裝,數據格式轉換,數據驗證等操作。
- 執行處理器Handler(Controller,也叫頁面控制器)。
- Handler執行完成返回ModelAndView。
- HandlerAdapter將Handler執行結果ModelAndView返回到DispatcherServlet。
- DispatcherServlet將ModelAndView傳給ViewReslover視圖解析器。
- ViewReslover解析后返回具體View。
- DispatcherServlet對View進行渲染視圖(即將模型數據model填充至視圖中)。
- 最終DispatcherServlet響應用戶。
通過以上對每個組件的介紹,以及每個組件的作用,和各組件中的調用關系;明白了這些之后,我們使用SpringMVC的時候,在腦子里就會一張流程圖,知道每一個請求來了之后,都做了哪些動作,如果后期我們想對一些請求進行干預的話,就可以方便的找到對應的組件,對應的位置來進行干預。