對JAVA程序員來講,做web開發(fā)最熟悉的框架莫過于SpringMVC了。之所以它能一統(tǒng)江湖,不是自己太優(yōu)秀,而是對手太坑了,不知道大家還記不記得2017年左右Struts2爆出了一個大漏洞,自此之后,Web開發(fā)領(lǐng)域的就是SpringMVC的天下了。
但是鑒于這么優(yōu)秀的框架,很多程序員還只是停留在會用的狀態(tài),對底層的原理卻不甚了解,所以今天咱么就來聊聊SpringMVC的工作原理。
三層架構(gòu)
在開始介紹SpringMVC之前,咱么要先來了解一下web開發(fā)的歷史。我們的開發(fā)架構(gòu)一般都是基于兩種形式,一種是C/S架構(gòu),也就是客戶端/服務(wù)器,另一種是B/S架構(gòu),也就是瀏覽器/服務(wù)器。而在JavaWeb開發(fā)中,幾乎都是采用B/S架構(gòu)的開發(fā)模式,在這種架構(gòu)模式中,將整個業(yè)務(wù)應(yīng)用劃分為三層架構(gòu),分別是::表現(xiàn)層(UI)、業(yè)務(wù)邏輯層(BLL)、數(shù)據(jù)訪問層(DAL),核心的思想就是“高內(nèi)聚,低耦合”。
- 表現(xiàn)層(UI)也就是我們常說的web層,展現(xiàn)給用戶的界面,即用戶在使用一個系統(tǒng)的時候的所見所得。講人話就是我們看到的網(wǎng)頁。
- 業(yè)務(wù)邏輯層(BLL)也就是我們常說的 service 層。主要對業(yè)務(wù)業(yè)務(wù)邏輯處理。
- 數(shù)據(jù)訪問層(DAL)也就是我們是常說的DAO 層。就是直接操作數(shù)據(jù)庫,針對數(shù)據(jù)的增添、刪除、修改、更新、查找等。
MVC框架模式
MVC全稱是【ModelView Controller】,模型(Model)是-視圖(View)-控制器(Controller)的縮寫,是一種軟件設(shè)計模式,是一種架構(gòu)思想,體現(xiàn)的是責(zé)任分離思想,各自做各自最擅長的事情。它是基于表現(xiàn)層把程序分為三大部分:模型、視圖、控制器,每一部分又有其單獨的意含義。
- 模型(Model ):數(shù)據(jù)模型,Model是數(shù)據(jù)模型,其實就是JavaBean對象,細(xì)分可以表示為業(yè)務(wù)組件(service)、領(lǐng)域模型組件(domain)等,Model包含要展示的數(shù)據(jù)和擁有的業(yè)務(wù)功能方法。
- 視圖(View ):數(shù)據(jù)展示,說人話就是用戶能看到的網(wǎng)頁界面,當(dāng)然該界面上還需要展示數(shù)據(jù)模型中的具體數(shù)據(jù)。
- 控制器(Controller):接收用戶請求,并分發(fā)給對應(yīng)的模型進(jìn)行處理處理完畢后把返回的模型數(shù)據(jù)返回給視圖進(jìn)行渲染,最終展示給用戶。
SpringMVC 的概念
SpringMVC 是一種基于Java 的實現(xiàn) MVC 設(shè)計模型的請求驅(qū)動類型的輕量級Web 框架,是Spring 框架提供的構(gòu)建Web 應(yīng)用程序的全功能 MVC模塊。目前SpringMVC 已經(jīng)成為目前最優(yōu)秀的MVC 框架之一。特別是支持RESTful編程風(fēng)格,更是和微服架構(gòu)的無縫契合。
SpringMVC的核心組件
1.DispatcherServlet【前端控制器】
相當(dāng)于中央處理器,用來分發(fā)請求的不同的處理流程,如:分發(fā)到HandlerMApping、HandlerAdapter、View resolver等。
2.Controller【處理器】
處理不同類型的業(yè)務(wù)請求,如:增刪改查的業(yè)務(wù)。
3.HandlerMapping【處理器映射器】
根據(jù)用戶請求找到Handler即處理器,SpringMvc提供了不同的映射器實現(xiàn)不同的映射方式,如:配置文件方式,實現(xiàn)接口方式,注解方式。
4.HandlerAdapter【處理器適配器】
通過HandlerAdapter對處理器進(jìn)行執(zhí)行,這是適配器模式的應(yīng)用,通過擴展適配器可以對更多類型的處理器進(jìn)行執(zhí)行。
5.View resolver【視圖解析器】
進(jìn)行視圖解析,根據(jù)邏輯視圖名解析成真正的視圖View視圖,最終需要通過網(wǎng)頁將數(shù)據(jù)模型展示給用戶。
執(zhí)行流程
下面我們來通過一張SpringMVC的流程圖,來看一下它的每個組件都是用來的干啥的,有什么作用,明白了這些之后,以后開發(fā)的時候就可以很清楚的知道一個請求過來之后,都經(jīng)過了哪些組件,每一個組件都發(fā)揮了什么樣的作用。
根據(jù)這張流程圖,我們再來分別解釋一下每一步以及每一個組件的具體作用。
- 用戶發(fā)送請求至前端控制器DispatcherServlet,進(jìn)行分發(fā)處理。
- DispatcherServlet收到請求調(diào)用處理器映射器HandlerMapping。
- 處理器映射器根據(jù)請求url找到具體的處理器,生成處理器執(zhí)行鏈HandlerExecutionChain(包括處理器對象和處理器攔截器)一并返回給DispatcherServlet。
- DispatcherServlet根據(jù)處理器Handler獲取處理器適配器HandlerAdapter執(zhí)行HandlerAdapter處理一系列的操作,如:參數(shù)封裝,數(shù)據(jù)格式轉(zhuǎn)換,數(shù)據(jù)驗證等操作。
- 執(zhí)行處理器Handler(Controller,也叫頁面控制器)。
- Handler執(zhí)行完成返回ModelAndView。
- HandlerAdapter將Handler執(zhí)行結(jié)果ModelAndView返回到DispatcherServlet。
- DispatcherServlet將ModelAndView傳給ViewReslover視圖解析器。
- ViewReslover解析后返回具體View。
- DispatcherServlet對View進(jìn)行渲染視圖(即將模型數(shù)據(jù)model填充至視圖中)。
- 最終DispatcherServlet響應(yīng)用戶。
通過以上對每個組件的介紹,以及每個組件的作用,和各組件中的調(diào)用關(guān)系;明白了這些之后,我們使用SpringMVC的時候,在腦子里就會一張流程圖,知道每一個請求來了之后,都做了哪些動作,如果后期我們想對一些請求進(jìn)行干預(yù)的話,就可以方便的找到對應(yīng)的組件,對應(yīng)的位置來進(jìn)行干預(yù)。