1. 程式人生 > >SSH三種框架及表示層、業務層和持久層的理解

SSH三種框架及表示層、業務層和持久層的理解

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

在專案開發的過程中,有時把整個專案分為三層架構,其中包括:
1、表示層(UI)、
2、業務邏輯層(BLL)
3、資料訪問層(DAL)。
三層的作用分別如下:
表示層:為使用者提供互動操作介面,這一點不論是對於Web還是WinForm都是如此,就是使用者介面操作。
業務邏輯層:負責關鍵業務的處理和資料的傳遞。複雜的邏輯判斷和涉及到資料庫的資料驗證都需要在此做出處理。根據傳入的值返回使用者想得到的值,或者處理相關的邏輯。
資料訪問層:負責資料庫資料的訪問。主要為業務邏輯層提供資料,根據傳入的值來操作資料庫,增、刪、改、查。



三層的理解
表示層的內容就是來和使用者打交道,通俗講就是展現給使用者的介面,使用者的要求都體現在介面上。
業務邏輯層的功能主要是實現一些具體問題的操作,它是表示層和資料訪問層之間溝通的橋樑,主要負責資料的傳遞和處理。
資料訪問層的功能就是對資料庫中表的內容的增刪改查。
三層的實現將我們的系統的實現過程分門別類,每一層自己做自己的事,互不影響,當我需要其他層的內容時,再去呼叫。當需要修改時只需改動本層的內容,不會影響到整個系統的程式碼。
就是傳說中的解耦。讓那個每一層只關心自己內部的事情,它只知道下層的存在,不知道上層的存在。達到區域性改變而不影響全域性的目的!


優點
1、開發人員可以只關注整個結構中的其中某一層;


2、可以很容易的用新的實現來替換原有層次的實現;
3、可以降低層與層之間的依賴;
4、有利於標準化;
5、利於各層邏輯的複用。


缺點
1、降低了系統的效能。如果不採用分層式結構,很多業務可以直接造訪資料庫,以此獲取相應的資料,如今卻必須通過中間層來完成。
2、有時會導致級聯的修改。這種修改尤其體現在自上而下的方向。如果在表示層中需要增加一個功能,為保證其設計符合分層式結構,可能需要在相應的業務邏輯層和資料訪問層中都增加相應的程式碼。
3、增加了開發成本。


三層與MVC的區別
1、MVC主要用於表現層,3層主要用於體系架構,3層一般是表現層、中間層、資料層,其中表現層又可以分成M、V、C,(ModelView Controller)模型-檢視-控制器

2、MVC是表現層的架構,MVC的Model實際上是ViewModel,即供View進行展示的資料。ViewModel不包含業務邏輯,也不包含資料讀取。

  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,也就選擇了你必須持續學習,經常關注最新的技術,瞭解它們,

    看是否適合你的需要,然後學習使用它們。

在用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屬性和一些其它 輔助方法,這也無可厚非,我自己也不能確定這對不對。


相關推薦

SSH框架表示業務持久理解

SSH:Struts(表示層)+Spring(業務層)+Hibernate(持久層) 在專案開發的過程中,有時把整個專案分為三層架構,其中包括:1、表示層(UI)、2、業務邏輯層(BLL)3、資料訪問層(DAL)。三層的作用分別如下:表示層:為使用者提供互動操作介面,這

併發伺服器實現方式之程序執行緒select

  前言:剛開始學網路程式設計,都會先寫一個客戶端和服務端,不知道你們有沒有試一下:再開啟一下客戶端,是連不上服務端的。還有一個問題不知道你們發現沒:有時啟伺服器,會提示“Address already in use”,過一會就好了,想過為啥麼?在這篇部落格會解釋這個問題。   但現實的伺服器都會連很多客戶

淺談Java裡的鎖:偏向鎖輕量級鎖重量級鎖

在學習sychronized關鍵字及其實現細節的時候,發現java中的三種鎖,偏向鎖,輕量級鎖,重量級鎖其實也有很多值得探究的地方,引入偏向鎖是為了在無多執行緒競爭的情況下儘量減少不必要的輕量級鎖執行

Jave虛擬機器劃分的個代: 年輕代年老代持久

虛擬機器中的共劃分為三個代:         年輕代(Young Generation)、年老代(Old Generation)和持久代(Permanent  Generation)。其中持久代主要存放的是Java類的類資訊,與垃圾收集要收集的Java物件關係 不大。年輕代和年老代的劃分是對垃 圾收集影響

Android UI框架模式-MVCMVPMVVM

MVC MVC全名是Model View Controller,是模型(model)-檢視(view)-控制器(controller)的縮寫。 呼叫關係 資料關係 View 接受使用者互動請求View 將請求轉交給ControllerController 操

常見存儲方式DASNASSAN的架構比較

DAS NAS SAN存儲的分類 根據服務器類型分為: 封閉系統的存儲(封閉系統主要指大型機) 開放系統的存儲(開放系統指基於window Unix Linux等操作系統的服務器) 開放系統的存儲分為:內置存儲和外掛存儲 外掛存儲根據連接方式分為:直連式存儲(DAS)和網絡化存儲(FAS);網絡化存儲根

SPII2CUART序列匯流排的原理區別應用

雜文 SPI、I2C、串列埠、我相信如果你是從事的是嵌入式開發,一定會用到這三種通訊協議,串列埠的話因為和波特率有關,所以一般的CPU或者MCU只會配有兩個或者三個串列埠,而資料的傳輸,的話SPI和I2C用得會比較多,下面找到了一篇部落格。轉過來、

PLSQL中的參數模式INOUTIN OUT

代碼 問題 ima .cn lang 傳遞 repl 一個 lin 1、IN模式 IN模式是參數的默認模式,這種模式就是在程序運行的時候已經具有值,在程序體中值不會改變。 錯誤例子: 1 create or replace procedure in_proc ( 2

HTML引入CSS樣式方法優先級 CSS樣式的寫法

分開 通過 str 相同 gif 標記 sof 偽類 cnblogs HTML引入CSS樣式三種方法及優先級: 方法 css的樣式引用由3種方式。分別為行內樣式、內部樣式(嵌入式)和外部樣式; 行內樣式: 在對象的標記內使用對象的s

轉:Tomcat內存溢出的情況解決辦法分析

個數 配置 param 釋放 blank pri 開始 clas ive Tomcat內存溢出的原因  在生產環境中tomcat內存設置不好很容易出現內存溢出。造成內存溢出是不一樣的,當然處理方式也不一樣。  這裏根據平時遇到的情況和相關資料進行一個總結。常見的一般會有下面

Spring之jdbcTemplate:查詢的方式(單個值單個對象對象集合)

res finally 結構 execute date rep frame 參數 system JdbcTemplateDemo2.java 1 package helloworld.jdbcTemplate; 2 3 import org.springf

使用ajax發送文件的方式預覽圖片的方法,上傳按鈕美化

absolut jquer 文件的 inpu headers return isp roc onchange 後端代碼 def upload(request): if request.method == "GET": return render(

LVS模式原理

普通 rect 擴展性 dns psu 更多 協議 solar 負載 LVS-NAT模式: LVS-DR模式: LVS-TUN模式: 一、Virtual server via NAT(VS-NAT)優點:集群中的物理服務器可以使用任何支持TCP/IP操作系統,物理服務器可以

適配器:BaseAdapterSimpleAdapterArrayAdapter

混合體 ack xtend ont 模擬 tro 其中 emc 集合 一、寫在前面:   本次我們來講解一下Android應用中三個適配器:BaseAdapter、SimpleAdapter和ArrayAdapter。其中常見的是BaseAdapter,也是個人推薦使用的適

檢測數據類型的方式區別

字符類 == console 布爾 實例對象 ole 方式 con div var a="i am string"; var b=[1,2,3]; var c=new String("abc"); //String類實例對象 //typeof: null 對象 數組

java排序二維陣列

排序 氣泡排序 public class TestDemo { //氣泡排序 public static void bubbleSort(int[] array) { boolean val = false; for (int i =

Linux下建立程序的方式特點

在Linux中主要提供了fork、vfork、clone三個程序建立方法。  在linux原始碼中這三個呼叫的執行過程是執行fork(),vfork(),clone()時,通過一個系統呼叫表對映到sys_fork(),sys_vfork(),sys_clone(),再在這三個函式中去呼叫d

Web Service平臺有元素構成:SOAPWSDLUDDI。區別聯絡

Web Service平臺有三種元素構成:SOAP、WSDL、UDDI。一個消費者可以在UDDI登錄檔查詢服務,取得服務的WSDL描述,然後通過SOAP來呼叫服務。SOAP、WSDL、UDDI的區別如下:1. SOAP(Simple Object Access Protocol,簡單物件訪問協議)① SOAP

框架模式

#MVC MVC是應用最廣泛的軟體架構之一,一般MVC分為:Model(模型)、Controller(控制器)和View(檢視)。這主要是基於分層的目的,讓彼此的職責分開。 View一般都是通過Controller來和Model進行聯絡的。Controller是Model和View的協調

vue.js 方式安裝 ( vue-cli ) 安裝詳解建立專案

  Vue.js(讀音 /vjuː/, 類似於 view)是一個構建資料驅動的 web 介面的漸進式框架。Vue.js 的目標是通過儘可能簡單的 API 實現響應的資料繫結和組合的檢視元件。它不僅易於上手,還便於與第三方庫或既有專案整合。     &nbs