1. 程式人生 > >java 三層架構ssh

java 三層架構ssh

本文轉載自王飛翔的部落格:http://hi.baidu.com/notatall_/item/c9499dcb7bf7260aad092ff0




一個spring2.5+hibernate3.2+struts2.0組合框架,使用spring IoC來管理應用 所有bean,包括struts2 action,充分發揮了spring輕量級框架 優勢。


 摘 要: 針對當前Web應用程式開發面臨的問題,結合目前比較流行的開源框架Spring、Struts和Hibernate,提出了一種開發J2EE Web應用的輕量級解決方案,以幫助開發人員在短期內搭建結構清晰、可複用性好、維護方便的Web應用程式。並且,通過案例具體說明了如何將這一方案應用到實際專案中。


關鍵詞: J2EE  MVC  Struts  Spring  Hibernate

    大型企業級Web應用系統的開發通常要求有一個良好的軟體架構、便於協作開發和擴充套件升級,而傳統的開發模式不能很好地滿足這些要求。本文針對當前Web應用程式開發面臨的問題,結合目前比較流行的開源框架SSH(Spring、Struts、Hibernate),提出一種開發J2EE 企業級Web應用的輕量級解決方案,並通過案例具體說明如何將這一方案應用到實際專案中。


1 框架技術
    著名的軟體大師Ralph Johnson對框架(Framework)進行了如下的定義: 框架是整個系統或系統的一部分的可重用設計,由一組抽象的類及其例項間的相互作用方式組成[1] 。
    框架一般具有即插即用的可重用性、成熟的穩定性以及良好的團隊協作性。J2EE複雜的多層結構決定了大型的J2EE專案需要運用框架和設計模式來控制軟體質量。目前,市場上出現了一些商業的、開源的基於J2EE的應用框架,其中主流的框架技術有:基於MVC模式的Struts框架和基於IoC模式的 Spring框架以及物件/關係對映框架Hibernate等。


1.1  表示層框架Struts
     Struts是一個在JSP Model2基礎上實現的MVC框架,主要分為模型(Model)、檢視(Viewer)和控制器(Controller)三部分,其主要的設計理念是通過控制器將表現邏輯和業務邏輯解耦,以提高系統的可維護性、可擴充套件性和可重用性[2] 。Struts框架的體系結構如圖1所示。


  下面就圖1所示的體系結構圖分析Struts框架中的MVC元件。
    (1)檢視:檢視部分主要由JSP頁面組成,其中沒有流程邏輯、業務邏輯和模型資訊,只有標記。Struts自身包含了一組標記庫(TagLib),這也是Struts的精華之一,靈活運用它們可以簡化JSP頁面的程式碼,提高開發效率。
    (2)控制器:Struts中的Controller主要是其自身提供的ActionServlet。ActionServlet接收所有來自客戶端的請求並根據配置檔案(struts-config.xml)中的定義將控制轉移到適當的Action物件。
    (3)模型:Struts沒有定義具體Model層的實現,Model層通常是和業務邏輯緊密相關的,有持續化的要求。目前在商業領域和開源世界,都有一些優秀的工具可以為Model層的開發提供便利。


1.2  業務邏輯層框架Spring
    Spring是一個解決了許多J2EE開發中常見問題並能夠替代EJB技術的強大的輕量級框架。這裡所說的輕量級指的是 Spring框架本身,而不是指Spring只能用於輕量級的應用開發。Spring的輕盈體現在其框架本身的基礎結構以及對其他應用工具的支援和裝配能力。與EJB這種龐然大物相比,Spring可使程式研發人員把各個技術層次之間的風險降低。
    Spring框架的核心是控制翻轉IoC(Inversion of Control)/依賴注入DI(Dependence Injection)機制。IoC是指由容器中控制組件之間的關係(這裡,容器是指為元件提供特定服務和技術支援的一個標準化的執行時的環境)而非傳統實現中由程式程式碼直接操控,這種將控制權由程式程式碼到外部容器的轉移,稱為“翻轉”[3] 。DI是對IoC更形象的解釋,即由容器在執行期間動態地將依賴關係(如構造引數、構造物件或介面)注入到元件之中[3] 。 Spring採用設值注入(使用Setter方法實現依賴)和構造子注入(在構造方法中實現依賴)的機制,通過配置檔案管理組建的協作物件,建立可以構造元件的IoC容器。這樣,不需要編寫工廠模式、單例模式或者其他構造的方法,就可以通過容器直接獲取所需的業務元件。Spring框架的結構如圖2所示。

 


   Spring框架由七個定義明確的模組組成,且每個模組或元件都可以單獨存在,或者與其他一個或多個模組聯合實現。Spring Core Container是一個用來管理業務元件的IoC容器,是Spring應用的核心;Spring DAO和Spring ORM不僅提供資料訪問的抽象模組,還集成了對Hibernate、JDO和iBatis等流行的物件關係對映框架的支援模組,並且提供了緩衝連線池、事務處理等重要的服務功能,保證了系統的效能和資料的完整性;Sprnig Web模組提供了Web應用的一些抽象封裝,可以將Struts、Webwork等Web框架與Spring整合成為適用於自己的解決方案。
    Spring框架可以成為企業級應用程式一站式的解決方案,同時它也是模組化的框架,允許開發人員自由地挑選適合自己應用的模組進行開發。Spring框架式是一個鬆耦合的框架,框架的部分耦合度被設計為最小,在各個層次上具體選用哪個框架取決於開發者的需要。


1.3 資料持久層框架Hibernate
    O/R mapping技術是為了解決關係型資料庫和麵向物件的程式設計之間不匹配的矛盾而產生的。Hibernate是目前最為流行的O/R mapping框架,它在關係型資料庫和Java物件之間做了一個自動對映,使得程式設計師可以以非常簡單的方式實現對資料庫的操作。Hibernate工作原理如圖3所示。

 


   Hibernate通過對JDBC的封裝,向程式設計師遮蔽了底層的資料庫操作,使程式設計師專注於OO程式的開發,有助於提高開發效率。程式設計師訪問資料庫所需要做的就是為持久化物件編制xml對映檔案[4] 。
    底層資料庫的改變只需要簡單地更改初始化配置檔案(hibernate.cfg.xml或者hibernate.properties)即可,不會對應用程式產生影響。
     Hibernate有自己的面向物件的查詢語言HQL,HQL功能強大,支援目前大部分主流的資料庫,如Oracle、DB2、MySQL、 Microsoft SQL Server等,是目前應用最廣泛的O/R對映工具。Hibernate為快速開發應用程式提供了底層的支援。


2 基於SSH組合框架的Web應用模型設計與實現
2.1 整合SSH的新型J2EE框架
  前面分析了基於J2EE的三種框架技術,下面通過整合以上三種框架技術來對傳統的J2EE Web開發模型加以改進,以形成一種新的、輕量型的J2EE架構。
  整合SSH框架 的系統框架圖 如圖4所示,系統從職責上分為四層:表示層、業務邏輯層、資料持久層和域模組層。其中使用Struts作為系統的整體基礎架構,負責MVC的分離,在 Struts框架的模型部分,利用Hibernate框架對持久層提供支援,業務層用Spring支援。具體做法是:用面向物件的分析方法根據需求提出一些模型,將這些模型實現為基本的Java物件,然後編寫基本的DAO介面,並給出Hibernate的DAO實現,採用Hibernate架構實現的 DAO類來實現Java類與資料庫之間的轉換和訪問,最後由Spring完成業務邏輯。

 


  系統的基本業務流程是:在表示層中,首先通過JSP頁面實現互動介面,負責傳送請求(Request)和接收響應(Response),然後Struts根據配置檔案 (struts-config.xml)將ActionServlet接收到的Request委派給相應的Action處理。在業務層中,管理服務元件的 Spring IoC容器負責向Action提供業務模型(Model)元件和該元件的協作物件資料處理(DAO)元件完成業務邏輯,並提供事務處理、緩衝池等容器元件以提升系統性能和保證資料的完整性。而在持久層中,則依賴於Hibernate的物件化對映和資料庫互動,處理DAO元件請求的資料,並返回處理結果。
  採用上述開發模型,不僅實現了檢視、控制器與模型的徹底分離,而且還實現了業務邏輯層與持久層的分離。這樣無論前端如何變化,模型層只需很少的改動,並且資料庫的變化也不會對前端有所影響,大大提高了系統的可複用性。而且由於不同層之間耦合度小,有利於團隊成員並行工作,大大提高了開發效率。


2.2 基於SSH框架 的Web應用系統的實現
  下面將通過一個實際的系統來展示如何進行基於SSH框架 的Web應用開發。該系統是為某通訊公司運營部開發的一個問答式系統,功能類似於百度知道和新浪愛問。由於系統的模組較多,下面就以一個使用者管理模組為例來說明系統的開發實現過程,並將按照資料持久層、業務邏輯層、表示層的順序說明系統構建過程。
  (1)資料持久層
  資料持久層由Java物件持久化類和資料訪問物件(DAO)組成。每個資料庫表都對應著一個持久化物件,這樣就給予了開發者使用OO思想設計和開發的便利,同時也遮蔽了具體的資料庫和具體的資料表、欄位,消除了對資料庫操作的硬編碼在重用性上的弊端。使用者資訊表的部分結構如表1所示。


  Hibernate通過對映(Mapping)檔案將物件(Object)與關係型資料(Relational)相關聯,因此需要編寫和資料庫表相對應的Java持久化類以及對應的對映檔案。有了Java持久化類後就可以在此基礎上實現資料訪問類。在Spring框架中,資料訪問類可以從輔助類 HibernateDaoSupport繼承,這極大地方便了Hibernate框架在Spring中的使用,相應的部分程式碼如下:
      public class UserDao 
          extends HibernateDaoSupport {
      public int add(User user) {
        return Integer.ParseInt(this.getHibernateTemplate().save(user).toString());
      }
      public List findAll() {
        return this.getHibernateTemplate().loadAll(User.class);
      }
      }
  具體的Hibernate資料來源、session工廠、事務管理、緩衝連線池等功能都由業務層的Spring容器提供。
  (2)業務邏輯層
  業務邏輯層由Spring框架支援,提供了處理業務邏輯的服務元件。開發者需要對業務物件建模,抽象出業務模型並封裝在Model元件中。由於資料持久層實現了Java持久化類並且封裝了資料訪問物件(DAO),因此可以在Model元件中方便地呼叫DAO元件來存取資料。Spring的IoC容器負責統一管理Model元件和DAO元件以及Spring所提供的事務處理、緩衝連線池等服務元件。
  在使用者管理模組中,通過業務建模建立了使用者模型UserService類,封裝了對使用者的許可權管理以及積分管理等功能。UserService類通過呼叫資料訪問類UserDao實現對使用者資料的操作。這些元件的關係將通過配置Spring框架的applicationContext.xml聯絡起來,配置檔案的主要內容如下:
       

    
      
     (3)表示層
     表示層結合JSP和Struts的TagLib庫處理顯示功能,利用ActionServlet將請求(*.do)對映到相應的Action,並由Action呼叫業務邏輯的服務元件,然後根據處理結果跳轉到Forword物件指定的響應頁面。
     業務流程的部署由struts-config.xml完成。下面以一個顯示所有使用者資訊的請求(ListUser.do)為例來說明配置檔案的使用。
      
     
      
      
     
    基於J2EE的Web應用以其層次性、平臺無關性的優勢已經逐漸成為了電子商務、電子政務主要的解決方案。本文針對傳統的J2EE Web應用開發的弊端,提出了一種利用輕量級框架來快速搭建Web應用的解決方案,並且通過其在實際專案中的應用,證明了採用此方案可以幫助開發人員在短時間內建立結構清晰、可重用性好、維護擴充套件方便的Web應用程式。


參考文獻
[1]  GAMMA E, HELM R, JOHNSON R, et al. Design patterns:Elements of reusable object-oriented software[M]. Addison  Wesley, 1994.
[2]  孫衛琴.精通Struts:基於MVC的Java Web設計與開發[M]. 北京:電子工業出版社,2004.
[3]  JOHNSON R, HOELLER J, ARENDSEN A, et al. Java/J2EE application framework reference document. V1.1. 
 2004.
[4]  徐長盛,戴超.一種快速開發Web應用程式方法的研究[J]. 計算機工程與設計,2004,(12):2237-2239.
[5]  夏昕,曹曉鋼,唐勇.深入淺出Hibernate[M]. 北京:電子工業出版社,2005.
[6]  JOHNSON R.Expert one-on-one J2EE design and development[M]. 魏海萍譯.北京:電子工業出版社,2003.

在用ssh 開發web應用時,需要對生成 各個類檔案進行組織,下面就對一個可行 目錄方案進行介紹:


 

譬如應用中有一個使用者管理模組,則在公共包下建立一個user包,如該公共包可以為com.simon.oa,

在user包下包括如下子包

1、controler包

該包放置各種struts action。

2、dao包

該包放置各類dao(data access object),也就是放置對資料庫訪問 實現類,在用myeclipse中 “Hibernate Reverse Engineering”進行反向操作時在某一個目錄中就會生成對應某個表 DAO,生成後可將該DAO拖到dao包中。在某些應用中將DAO作為介面,在該介面中包括所有對資料庫 操作方法,然後在dao包建立一個hibernate包,在hibernate包中放置對DAO介面 實現,譬如:UserDAO介面有一個實現類為UserDaoImpl,將該類放置到hibernate包中,實際 開發傾向於後一種方式,因為對這個DAO介面可以實現spring IoC操作。(不知道myeclipse對此是怎麼考慮 ,這個問題讓我糾纏了很久,誤將DAO理解成一個能夠進行實際操作 類,而不是一個介面,以後開發要注意 )

3、model包

該包中放置hibernate反向工程生成 bean和該bean對應 .hbm.xml檔案。

4、service包

該包放置業務操作類,譬如使用者服務類,一般情況將該使用者操作類提取一個介面,然後在service包下生成一個impl包,在impl包中才放置使用者操作介面 實現類。該使用者介面實現類中呼叫DAO介面對資料庫進行操作,而呼叫該實現類 方法在struts action中。

5、vo包(value object)

vo包中 中包括struts中使用 POJO及actionform等資訊。

VO:  Value Object
DTO: Data Transfer Object
個人理解VO和DTO是類似 東西,原則上VO和DTO只有Public Fields,主要用於程序之間資料傳遞 問題,VO和DTO不會傳遞到表示層,在業務層就會被吸收。但看到很多人在建立VO和DTO時,也含有Setter,Getter屬性和一些其它 輔助方法,這也無可厚非,我自己也不能確定這對不對。