天天看點

JAVA三層架構,持久層,業務層,表現層的了解

SSH:

Struts(表示層)+Spring(業務層)+Hibernate(持久層)

Struts:

Struts是一個表示層架構,主要作用是界面展示,接收請求,分發請求。

在MVC架構中,Struts屬于VC層次,負責界面表現,負責MVC關系的分發。

(View:沿用JSP,HTTP,Form,Tag,Resourse ;

Controller:ActionServlet,struts-config.xml,Action)

Hibernate:Hibernate是一個持久層架構,它隻負責與關系資料庫的操作。

Spring:Spring是一個業務層架構,是一個整合的架構,能夠很好地黏合表示層與持久層。

我們知道,傳統的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軟體公司對新進員工的基本要求。 其他 Java這個名詞似乎注定和開源緊密聯系在一起了,在Java界,每天都有大量的開源技術出現,由于是開放源代碼的,技術中存在的問題和不足很快就會被人發現,開源軟體提供者會很快的修正或擴充這些技術,是以版本更新很快,幾個星期或者幾天就有一個新版本出來。 當我們在技術線路中選擇了Java,也就選擇了你必須持續學習,經常關注最新的技術,了解它們,看是否适合你的需要,然後學習使用它們。