1. 程式人生 > >javaweb三大框架和MVC設計模式

javaweb三大框架和MVC設計模式

detail struts2 萬能 sdn 發的 struts 其他 article 改進

javaweb三大框架和MVC設計模式

轉載,原文請見https://blog.csdn.net/sunpeng19960715/article/details/50890705

一、MVC設計模式

1.MVC的概念

首先我們需要知道MVC模式並不是javaweb項目中獨有的,MVC是一種軟件工程中的一種軟件架構模式,把軟件系統分為三個基本部分:模型(Model)、視圖(View)和控制器(Controller),即為MVC。它是一種軟件設計的典範,最早為Trygve Reenskaug提出,為施樂帕羅奧多研究中心(Xerox PARC)的Smalltalk語言發明的一種軟件設計模式。

2.MVC的詳解

雖然MVC並不是Java當中獨有的,但是現在幾乎所有的B/S的架構都采用了MVC框架模式,但是MVC在B/S架構中並沒有完全地實現,其實我們根本不需要掌握未實現的部分。
·控制器Controller:控制器即是控制請求的處理邏輯,對請求進行處理,負責請 求轉發;
·視圖View:視圖即是用戶看到並與之交互的界面,比如HTML(靜態資源),JSP(動態資源)等等。
·模型Model:模型代表著一種企業規範,就是業務流程/狀態的處理以及業務規則的規定。業務流程的處理過程對其他層來說是不透明的,模型接受視圖數據的請求,並返回最終的處理結果。業務模型的設計可以說是MVC的核心。

3.MVC模式的用武之地

MVC模式被廣泛用於Java的各種框架中,比如Struts2、Spring MVC等等都用到了這種思想。

Struts2是基於MVC的輕量級的web應用框架。基於MVC,說明基於Struts2開發的Web應用自然就能實現MVC,也說明Struts2著力於在MVC的各個部分為我們的開發提供相應幫助。

二、Javaweb經典三層架構

1.Javaweb經歷了三個時期

①JSP Model1第一代
JSP Model1是JavaWeb早期的模型,它適合小型Web項目,開發成本低!Model1第一代時期,服務器端只有JSP頁面,所有的操作都在JSP頁面中,連訪問數據庫的API也在JSP頁面中完成。也就是說,所有的東西都耦合在一起,對後期的維護和擴展極為不利。

技術分享圖片

②JSP Model1第二代
JSP Model1第二代有所改進,把業務邏輯的內容放到了JavaBean中,而JSP頁面負責顯示以及請求調度的工作。雖然第二代比第一代好了些,但還讓JSP做了過多的工作,JSP中把視圖工作和請求調度(控制器)的工作耦合在一起了。

技術分享圖片

③JSP Model2
JSP Model2模式已經可以清晰的看到MVC完整的結構了。
·JSP:視圖層,用來與用戶打交道。負責接收用來的數據,以及顯示數據給用戶;
·Servlet:控制層,負責找到合適的模型對象來處理業務邏輯,轉發到合適的視圖;
JavaBean:模型層,完成具體的業務工作,例如:開啟、轉賬等。

技術分享圖片

這就是javaweb經歷的三個年代,JSP Model2適合多人合作開發大型的Web項目,各司其職,互不幹涉,有利於開發中的分工,有利於組件的重用。但是,Web項目的開發難度加大,同時對開發人員的技術要求也提高了。

2.JavaWeb經典三層框架

我們常說的三層框架是由JavaWeb提出的,也就是說這是JavaWeb獨有的!
所謂三層是表述層(WEB層)、業務邏輯層(Business Logic),以及數據訪問層(Data Access)。
·WEB層:包含JSP和Servlet等與WEB相關的內容;
·業務層:業務層中不包含JavaWeb API,它只關心業務邏輯;
·數據層:封裝了對數據庫的訪問細節;

  註意,在業務層中不能出現JavaWeb API,例如request、response等。也就是說,業務層代碼是可重用的,甚至可以應用到非Web環境中。業務層的每個方法可以理解成一個萬能,例如轉賬業務方法。業務層依賴數據層,而Web層依賴業務層!
技術分享圖片

註:網上很多人在討論MVC究竟是一種框架模式還是一種設計模式(百度百科中強行解釋其為一種框架模式而不是一種設計模式),雖然Java中的23種設計模式裏並沒有MVC,但是我認為討論這個問題沒有太大的必要。我們大可將他作為一種思想,我們需要做的僅僅是理解它,應用它,掌握其中的思想,這才是我們需要做的。

javaweb三大框架和MVC設計模式