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