Java知識拾遺:三大框架的技術起源
Java知識拾遺:三大框架的技術起源
Struts、Hibernate和Spring是我們Java開發中的常用關鍵,他們分別針對不同的應用場景給出最合適的解決方案。但你是否知道,這些知名框架最初是怎樣產生的?
我們知道,傳統的Java Web應用程式是採用JSP+Servlet+Javabean來實現的,這種模式實現了最基本的MVC分層,使的程式結構分為幾層,有負責前臺展示的JSP、負責流程邏輯控制的Servlet以及負責資料封裝的Javabean。但是這種結構仍然存在問題:如JSP頁面中需要使用符號嵌入很多的Java程式碼,造成頁面結構混亂,Servlet和Javabean負責了大量的跳轉和運算工作,耦合緊密,程式複用度低等等。
Struts
為了解決這些問題,出現了Struts框架,它是一個完美的MVC實現,它有一箇中央控制類(一個Servlet),針對不同的業務,我們需要一個Action類負責頁面跳轉和後臺邏輯運算,一個或幾個JSP頁面負責資料的輸入和輸出顯示,還有一個Form類負責傳遞Action和JSP中間的資料。JSP中可以使用Struts框架提供的一組標籤,就像使用HTML標籤一樣簡單,但是可以完成非常複雜的邏輯。從此JSP頁面中不需要出現一行包圍的Java程式碼了。
可是所有的運算邏輯都放在Struts的Action裡將使得Action類複用度低和邏輯混亂,所以通常人們會把整個Web應用程式分為三層,Struts負責顯示層,它呼叫業務層完成運算邏輯,業務層再呼叫持久層完成資料庫的讀寫。
使用JDBC連線來讀寫資料庫,我們最常見的就是開啟資料庫連線、使用複雜的SQL語句進行讀寫、關閉連線,獲得的資料又需要轉換或封裝後往外傳,這是一個非常煩瑣的過程。
Hibernate
這時出現了Hibernate框架,它需要你建立一系列的持久化類,每個類的屬性都可以簡單的看做和一張資料庫表的屬性一一對應,當然也可以實現關聯式資料庫的各種表件關聯的對應。當我們需要相關操作是,不用再關注資料庫表。我們不用再去一行行的查詢資料庫,只需要持久化類就可以完成增刪改查的功能。使我們的軟體開發真正物件導向,而不是面向混亂的程式碼。我的感受是,使用Hibernate比JDBC方式減少了80%的程式設計量。
現在我們有三個層了,可是每層之間的呼叫是怎樣的呢?比如顯示層的Struts需要呼叫一個業務類,就需要new一個業務類出來,然後使用;業務層需要呼叫持久層的類,也需要new一個持久層類出來用。通過這種new的方式互相呼叫就是軟體開發中最糟糕設計的體現。簡單的說,就是呼叫者依賴被呼叫者,它們之間形成了強耦合,如果我想在其他地方複用某個類,則這個類依賴的其他類也需要包含。程式就變得很混亂,每個類互相依賴互相呼叫,複用度極低。如果一個類做了修改,則依賴它的很多類都會受到牽連。 為此,出現Spring框架。
Spring
Spring的作用就是完全解耦類之間的依賴關係,一個類如果要依賴什麼,那就是一個介面。至於如何實現這個介面,這都不重要了。只要拿到一個實現了這個介面的類,就可以輕鬆的通過xml配置檔案把實現類注射到呼叫介面的那個類裡。所有類之間的這種依賴關係就完全通過配置檔案的方式替代了。所以Spring框架最核心的就是所謂的依賴注射和控制反轉。
現在的結構是,Struts負責顯示層,Hibernate負責持久層,Spring負責中間的業務層,這個結構是目前國內最流行的Java Web應用程式架構了。另外,由於Spring使用的依賴注射以及AOP(面向方面程式設計),所以它的這種內部模式非常優秀,以至於Spring自己也實現了一個使用依賴注射的MVC框架,叫做Spring MVC,同時為了很好的處理事物,Spring整合了Hibernate,使事物管理從Hibernate的持久層提升到了業務層,使用更加方便和強大。
Struts框架是2000年就開始起步了,到目前已經發展了5年,技術相當成熟,目前全球Java開發中Struts框架是顯示層技術中當之無愧的王者。它擁有大量的使用者群和很好的開發團隊。這也是國內大部分Java軟體公司對新進員工的基本要求。
相關文章
- golang拾遺:內建函式len的小知識Golang函式
- Java Web 拾遺JavaWeb
- 【106天】前端碎片知識拾遺00004前端
- 【105天】前端碎片知識拾遺00003前端
- Java個人技術知識點總結(框架篇)Java框架
- 【java web】--Ajax拾遺JavaWeb
- 【ASIC設計】FPGA小知識拾遺(不斷更新...)FPGA
- 知識點拾遺——Option 將其中的引用轉換為值
- 基於gin的golang web開發:Gin技術拾遺GolangWeb
- [C#.NET 拾遺補漏]02:陣列的幾個小知識C#陣列
- 【Java學習筆記】拾遺Java筆記
- [C#.NET 拾遺補漏]11:最基礎的執行緒知識C#執行緒
- mongoose 拾遺Go
- 遺漏的知識點
- IAST技術知識-Java環境Agent部署知識乾貨分享ASTJava
- JAVA 拾遺 — CPU Cache 與快取行Java快取
- 前端技能拾遺前端
- Linux拾遺Linux
- [MASM拾遺]OffsetASM
- java面試需要掌握知識點|掘金技術徵文Java面試
- JAVA拾遺 — JMH與8個測試陷阱Java
- [NLP] 知識抽取技術
- 開發Webview的技術,小的技術知識點WebView
- Oracle知識拾漏兩則Oracle
- 物件導向拾遺物件
- C語言拾遺C語言
- Java個人技術知識點總結(優化篇)Java優化
- java框架之Hibernate框架知識點整理。Java框架
- 非常硬核的技術知識-CopyOnWrite思想
- 容易遺忘的知識點總結
- golang拾遺:嵌入型別Golang型別
- docker拾遺-之再入坑Docker
- Unix廣告拾遺 by Dennis Ritchie
- 【JS拾遺】函式的引數JS函式
- 遊戲技術美術之<技術&美術>知識構成遊戲
- Java面試之技術框架Java面試框架
- Java個人技術知識點總結(資料庫篇)Java資料庫
- Java個人技術知識點總結(最佳化篇)Java