Posted on 2010-03-24 23:35
Gavin.lee 閱讀(317)
評論(0) 編輯 收藏 所屬分類:
SSH2 --Struts2
原文:http://hi.baidu.com/%D0%C4%CB%E9%E5%D0%D2%A3/blog/item/e6ae7ed87146ac3232fa1c40.html
傳統的java
web應用程序是采用jsp+servlet+javabean來實現的,這種模式實現了最基本的MVC分層,使的程序結構分為幾層,有負責顯示的
jsp、負責流程邏輯控制的servlet、負責數據封裝的javabean。但是這種結構仍然存在問題:如jsp頁面中需要使用<%
%>符號嵌入很多的java代碼,造成頁面結構混亂,servlet和javabean負責了大量的跳轉和運算工作,耦合緊密,程序復用度低等等。
于是先出現了struts框架,它是一個完美的MVC實現,它有一個中央控制類(一個Servlet),針對不同的業務,我們需要一個Action類負責
頁面跳轉和后臺邏輯運算,一個或幾個jsp頁面負責數據的輸入和輸出顯示,還有一個Form類負責傳遞Action和jsp中間的數據。jsp中可以使用
struts框架提供的一組標簽,就像使用html標簽一樣簡單,但是可以完成非常復雜的邏輯。從此jsp頁面中不需要出現一行<%%>包圍
的java代碼了。
可是所有的運算邏輯都放在struts的Action里將使得Action類復用度低和邏輯混亂,所以通常人們會把整個web應用程序分為三層,struts負責顯示層,它調用業務層完成運算邏輯,業務層再調用持久層完成數據庫的讀寫。
使用jdbc連接來讀寫數據庫,我們最常見的就是打開數據庫連接、使用復雜的sql語句進行讀寫、關閉連接,獲得的數據又需要轉換或封裝后往外傳,這是一個非常煩瑣的過程。
這時出現了hibernate框架,它需要你創建一系列的持久化類,每個類的屬性都可以簡單的看做和一張數據庫表的屬性一一對應,當然也可以實現關系數據
庫的各種表件關聯的對應。然后我們****作時,只需要去****作這些持久化類,而不用再關注數據庫表。我們不用再去一行行的查詢數據庫,只需要
****作持久化類就可以完成增刪改查的功能。使我們的軟件開發真正面向對象,而不是面向混亂的代碼。我的感受是,使用hibernate比jdbc方式
減少了80%的編程量。
現在我們有三個層了,可是每層之間的調用是怎樣的呢?比如顯示層的struts需要調用一個業務類,就需要new一個業務類出來,然后使用;業務層需要調
用持久層的類,也需要new一個持久層類出來用。通過這種new的方式互相調用就是軟件開發中最糟糕設計的體現。簡單的說,就是調用者依賴被調用者,它們
之間形成了強耦合,如果我想在其他地方復用某個類,則這個類依賴的其他類也需要包含。程序就變得很混亂,每個類互相依賴互相調用,復用度極低。如果一個類
做了修改,則依賴它的很多類都會受到牽連。
為此,出現spring框架,它的作用就是完全解耦類之間的依賴關系,一個類如果要依賴什么,那就是一個接口。至于如何實現這個接口,這都不重要了。只要
拿到一個實現了這個接口的類,就可以輕松的通過xml配置文件把實現類注射到調用接口的那個類里。所有類之間的這種依賴關系就完全通過配置文件的方式替代
了。所以spring框架最核心的就是所謂的依賴注射和控制反轉。
現在的結構是,struts負責顯示層,hibernate負責持久層,spring負責中間的業務層,這個結構是目前國內最流行的Java
Web應用程序架構了。另外,由于Spring使用的依賴注射以及AOP(面向方面編程),所以它的這種內部模式非常優秀,以至于Spring自己也實現
了一個使用依賴注射的MVC框架,叫做Spring
MVC,同時為了很好的處理事物,Spring集成了hibernate,使事物管理從Hibernate的持久層提升到了業務層,使用更加方便和強大。