您好,登錄后才能下訂單哦!
在穿越了 Web 容器和Web 應(yīng)用之后,HTTP 請求將被投送到 Spring 框架,我們繼續(xù)剖析后續(xù)流程。Web 應(yīng)用與 Spring MVC 的銜接是通過配置文件 mvc-servlet.xml 完成的,我們通過這份配置文件定義構(gòu)成 Spring MVC 的各種核心組件和初始化配置,其中包括:控制器 Controller、視圖解析器 ViewResolver、視圖 View 等等。不同組件分別承擔(dān)不同的功能,在介紹 Spring 框架處理 HTTP 請求流程之前,我們照例先了解一下這些核心組件。
我們應(yīng)用開發(fā)者在使用 Spring 時接觸最多的就是各種注解,包括:@Component、@Controller、@Service、@Repository 等,這些都是 Spring 的核心組件。除此之外,我們還會使用 @RequestMapping、@RequestParam、@PathVariable、@RequestBody 等輔助性注解:
數(shù)據(jù)存儲對象 Repository:也稱為數(shù)據(jù)訪問對象 DAO(Data Access Object),不管采用什么開發(fā)框架,大部分應(yīng)用都需要跟數(shù)據(jù)庫交互,DAO 就是將訪問數(shù)據(jù)庫操作做了封裝,隔離了 SQL 相關(guān)復(fù)雜度。
抵達 Spring MVC 的所有 HTTP 請求均由前置分發(fā)器 DispatcherServlet 統(tǒng)一分發(fā),在將請求分發(fā)給特定的控制器 Controller 之前需要借助處理器映射 HandlerMapping 來定位,大概過程如下:
在填充處理器 Handler 入?yún)⒌倪^程中,Spring 還會根據(jù)配置做些預(yù)處理工作:
Spring Web 應(yīng)用架構(gòu)經(jīng)歷了多個階段的發(fā)展,最初主流的前端視圖技術(shù)就是 JSP,在此基礎(chǔ)上又演化出了三劍客框架 SSH(Struts\Spring\Hibernate),但這時候前后端其實還是耦合在一起的,不管是 JSP 還是 SSH,在前面 Spring 框架處理 HTTP 請求的流程中,必須要依賴視圖解析器 ViewResolver 和視圖 View。
從 Spring 誕生到現(xiàn)在已經(jīng)15年多了,它關(guān)聯(lián)的后端技術(shù)演化其實沒有前端那么快,主要原因就是前端需求越來越豐富多樣,前端視圖層的開發(fā)工作量和復(fù)雜度不斷增加。在這樣的背景之下,越來越多的前端工程化解決方案涌現(xiàn),其中最有成效的就是前后端分離,從 AngularJS\Backbone.js 到現(xiàn)在 React\Vue 等。在這種前后端分離架構(gòu)下,前端就全部由靜態(tài)資源(HTML\Javascript\CSS)等構(gòu)成,可以獨立部署在 Web 服務(wù)器當(dāng)中,這樣 Spring 框架就不需要再處理視圖相關(guān)的內(nèi)容,控制器 Controller 不再返回 ModelAndView,只需要反饋模型數(shù)據(jù)了。
本文主要價值是幫助大家梳理出端到端的全流程框架,也就是我們常說的全局視角或者上帝視角。有了這個框架之后,我們可以根據(jù)自己的需要按圖索驥找相關(guān)節(jié)點的資料來研究學(xué)習(xí),不至于陷入細(xì)節(jié)找不到方向。當(dāng)然,考慮到我們每個人的工作學(xué)習(xí)情況不同,平時遇到的問題也不同,本文內(nèi)容無法覆蓋所有人遇到的問題,歡迎大家留言提問,也歡迎關(guān)注我的博客或公號“IT老兵哥”交流互動,我會盡力盡快解答大家提出的問題,謝謝!
本系列其他文章索引如下:
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。