Java三大框架SSH與MVC的設計模式

現在許許多多的初學者和程序員,都在趨之若鶩地學習Web開發的寶典級框架:Struts2,Spring,Hibernate。似乎這些框架成爲了一個人是否精通Java,是否會寫J2EE程序的唯一事實標準和找工作的必備基礎。

爲什麼要學習這些框架?這些框架的本質到底是什麼?似乎很少很少有人能夠給我非常滿意的答覆。因爲他們都在爲了學習而學習,
爲了工作而學習,而不是在真正去深入瞭解一個框架。其實所有的人都應該思考這樣的問題:爲什麼要學習框架?框架到底給我帶來了
什麼?
開始學習時嘗試過不用框架在HTML代碼中編寫Java代碼來完成邏輯的方式存在着不少問題:

  1. Java代碼由於混雜在一個HTML環境中而顯得混亂不堪,可讀性非常差。一個JSP文件有時候會變成幾十K,甚至上百K。要找一段邏輯,經常無法定位。

  2. 編寫代碼時非常困惑,不知道代碼到底應該寫在哪裏,也不知道別人是不是已經曾經實現過類似的功能,到哪裏去引用。

  3. 突然之間,某個需求發生了變化。於是,每個人矇頭開始全程替換,還要小心翼翼的,生怕把別人的邏輯改了。

  4. 邏輯處理程序需要自己來維護生命週期,對於類似數據庫事務、日誌等衆多模塊無法統一支持。

框架不重要,概念是王道。只要能夠深刻理解MVC的概念,框架對你來說,只是一個jar包而已。


在這幅圖中,MVC三個框框各司其職,結構清晰明朗。不過我覺得這幅圖忽略了一個問題,就是數據是動的,數據在View和Control層一旦動起來,就會產生許多的問題:

  1. 數據從View層傳遞到Control層,如何使得一個個扁平的字符串,轉化成一個個生龍活虎的Java對象。

  2. 數據從View層傳遞到Control層,如何方便的進行數據格式和內容的校驗?

  3. 數據從Control層傳遞到View層,一個個生龍活虎的Java對象,又如何在頁面上以各種各樣的形式展現出來。

Java三大框架主要用來做WEN應用。Struts主要負責表示層的顯示Spring利用它的IOC和AOP來處理控制業務(負責對數據庫的操作)Hibernate主要是數據持久化到數據庫

一 .Struts框架:struts是開源軟件。使用Struts的目的是爲了幫助我們減少在運用MVC設計模型來開發Web應用的時間。如果我們想混合使用Servlets和JSP的優點來建立可擴展的應用,struts是一個不錯的選擇。

    1.流程:服務器啓動後,根據web.xml加載ActionServlet讀取struts-config.xml文件內容到內存。

    2.架構:Struts對Model,View和Controller都提供了對應的組件。ActionServlet,這個類是Struts的核心控制器,負責攔截來自用戶的請求。

        Model部分:由JavaBean組成,ActionForm用於封裝用戶的請求參數,封裝成ActionForm對象,該對象被ActionServlet轉發給Action,Action根據ActionFrom裏面的請求參數處理用戶的請求。JavaBean則封裝了底層的業務邏輯,包括數據庫訪問等。

View部分:該部分採用JSP實現。Struts提供了豐富的標籤庫,通過標籤庫可以減少腳本的使用,自定義的標籤庫可以實現與Model的有效交互,並增加了現實功能。對應上圖的JSP部分。

   Controller組件:Controller組件有兩個部分組成——系統核心控制器,業務邏輯控制器。   系統核心控制器,對應上圖的ActionServlet。該控制器由Struts框架提供,繼承HttpServlet類,因此可以配置成標註的Servlet。該控制器負責攔截所有的HTTP請求,然後根據用戶請求決定是否要轉給業務邏輯控制器。業務邏輯控制器,負責處理用戶請求,本身不具備處理能力,而是調用Model來完成處理。對應Action部分。

 二.Spring框架

Spring是一個解決了許多在J2EE開發中常見的的問題的強大框架。Springle提供了管理業務對象的一致方法並且鼓勵了注入對接口編程而不是對類變成的好習慣。Spring的架構基礎是基於使用JavaBean屬性的Inversion of Control 容器。然而Spring在使用IoC容器作爲構建玩關注所有架構層層的完整解決方案方面是獨一無二的。Spring提供了唯一的數據管理抽象包括簡單和有效率的JDBC框架,極大的改進了效率並且減少了可能的錯誤。Spring的數據訪問架構還集成了Hibernate和其他O/R mapping 解決方案。

三.Hibernate框架

Hibernate 是一個開源代碼的對象關係映射框架,對JDBC驚醒了費城輕量級的的對象封裝,使得Java程序員可以隨心所欲的使用對象變成思維來操作數據庫。Hebernate可以應用在任何使用JDBC的場合,既可以在java的客戶端程序使用,也可以在Servlet/JSP的Web應用中使用最具革命意義的事,Hibernate可以在應用EJB的J2EE架構中取代CMP,完成數據持久化的重任

Hibernate的核心接口一共有5個,分別爲:Session、SessionFactory、Transaction、Query和Configuration。這5個核心接口在任何開發中都會用到。通過這些接口,不僅可以對持久化對象進行存取,還能夠進行事務控制。下面對這五個核心接口分別加以介紹。

1.Session接口:負責執行被持久化對象的CRUD操作(CRUD的任務是完成與數據庫的交流,包含了很多常見的SQL語句。)。但需要注意的是Session對象是非線程安全的。同時,Hibernate的session不同於JSP應用中的HttpSession。這裏當使用session這個術語時,其實指的是Hibernate中的session,而以後會將HttpSession對象稱爲用戶session。

2.SessionFactory接口:負責初始化Hibernate。它充當數據存儲源的代理,並負責創建Session對象。這裏用到了工廠模式。需要注意的是SessionFactory並不是輕量級的,因爲一般情況下,一個項目通常只需要一個SessionFactory就夠,當需要操作多個數據庫時,可以爲每個數據庫指定一個SessionFactory。

3.Configuration接口:負責配置並啓動Hibernate,創建SessionFactory對象。在Hibernate的啓動的過程中,Configuration類的實例首先定位映射文檔位置、讀取配置,然後創建SessionFactory對象。

4.Transaction接口:負責事務相關的操作。它是可選的,開發人員也可以設計編寫自己的底層事務處理代碼。

5.Query和Criteria接口:負責執行各種數據庫查詢。它可以使用HQL語言或SQL語句兩種表達方式。

框架是爲了解決一個又一個在Web開發中所遇到的問題而誕生的。不同的框架,都是爲了解決不同的問題,但是對於程序員而言,他們只是jar包而已。框架的優缺點的評論,也完全取決於其對問題解決程度和解決方式的優雅性的評論。所以,千萬不要爲了學習框架而學習框架,而是要爲了解決問題而學習框架,這纔是一個程序員的正確學習之道。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章