1. 程式人生 > >Action、Dao、Service三層的功能劃分

Action、Dao、Service三層的功能劃分

連接數據庫 數據庫表 客戶服務 service 服務員

原文地址

Action是管理業務(Service)調度和管理跳轉的。


Service是管理具體的功能的。

Action只負責管理,而Service負責實施。

DAO只完成增刪改查,雖然可以1-n,n-n,1-1關聯,模糊、動態、子查詢都可以。但是無論多麽復雜的查詢,dao只是封裝增刪改查。至於增刪查改如何去實現一個功能,dao是不管的。

總結這三者,通過例子來解釋:

Action像是服務員,顧客點什麽菜,菜上給幾號桌,都是ta的職責;

Service是廚師,action送來的菜單上的菜全是ta做的;

Dao是廚房的小工,和原材料打交道的事情全是ta管。 相互關系是,小工(dao)的工作是要滿足廚師(service)的要求,廚師要滿足服務員(action)轉達的客戶(頁面用戶)的要求,服務員自然就是為客戶服務嘍。

現在最基本的分層方式,結合了SSH架構。Model層就是對應的數據庫表的實體類。Dao層是使用了Hibernate連接數據庫、操作數據庫(增刪改查)。Service層:引用對應的Dao數據庫操作。Action層:引用對應的Service層,在這裏結合Struts的配置文件,跳轉到指定的頁面,當然也能接受頁面傳遞的請求數據,也可以做些計算處理。

以上的Hibernate, Struts,都需要註入到Spring的配置文件中,Spring把這些聯系起來,成為一個整體。



2. 三大框架Struts/Hibernate/Spring

簡單地說:

Struts——控制用的;

Hibernate——操作數據庫的;

Spring——解耦用的。

詳細地說:

Struts在SSH框架中起控制的作用,其核心是Controller,即ActionServlet,而ActionServlet的核心就是Struts-config.xml,主要控制邏輯關系的處理。

Hibernate是數據持久化層,是一種新的對象、關系的映射工具,提供了從Java類到數據表的映射,也提供了數據查詢和恢復等機制,大大減少數據訪問的復雜度。把對數據庫的直接操作,轉換為對持久對象的操作。

Spring是一個輕量級的控制反轉(IoC)和面向切面(AOP)的容器框架。面向接口的編程,由容器控制程序之間的依賴關系,而非傳統實現中,由程序代碼直接操控。這就是所謂“控制反轉”的概念所在:(依賴)控制權由應用代碼中轉到了外部容器,控制權的轉移,是所謂反轉。依賴註入,即組件之間的依賴關系由容器在運行期決定,形象地說,即由容器動態地將某種依賴關系註入到組件之中,起到的主要作用是解耦。

Struts、Spring、Hibernate在各層的作用:

(1)Struts負責Web層:ActionFormBean接收網頁中表單提交的數據,然後通過Action進行處理,再Forward到對應的網頁。在Struts-config.xml中定義<action-mapping>,ActionServlet會加載。

(2) Spring負責業務層管理,即Service(或Manager)。

Service為action提供統計的調用接口,封裝持久層的DAO;

可以寫一些自己的業務方法;

統一的Javabean管理方法;

聲明式事務管理;

集成Hibernate。


(3)Hibernate,負責持久化層,完成對數據庫的crud操作。提供OR/Mapping。它由一組.hbm.xml文件和POJO,是跟數據庫中的表相對應的。然後定義DAO,這些是跟數據庫打交道的類,它們會使用PO。

3. 框架業務邏輯分析:

在Struts + Spring + Hibernate的系統中,

對象的調用流程是:JSP—Action—Service—DAO—Hibernate。

數據的流向是:ActionFormBean接受用戶的數據,Action將數據從ActionFormBean中取出,封裝成VO或PO,再調用業務層的Bean類,完成各種業務處理後再Forward。而業務層Bean收到這個PO對象之後,會調用DAO接口方法,進行持久化操作。

SSH框架的優點:

Hibernate的最大好處就是根據數據庫的表,反向生成實體類,並且還有關系在裏面,還有就是它對數據的操作也很方便;

Spring,省去了在類裏面new對象的過程,把這個調用與被調用的關系直接展示到了配置文件裏,做任何操作都變得簡單了。

簡單流程舉例說明:

程序框架搭建好,並且把各種jar包導入後,就開始進行業務邏輯分析——

假設一個最基本的註冊功能:頁面有兩個文本框,一個用戶名(username)和一個密碼(password)。以QQ註冊網頁說明,這裏以昵稱和密碼為代表進行舉例。



首先是action層:它是負責在頁面和程序之間傳輸數據的,還有作用是做頁面跳轉。頁面由用戶填寫表單數據,點擊提交按鈕,頁面的表單數據由Hibernate自動封裝到該頁面表單所對應的ActionFrom(ActionFrom跟實體類不是一個東西,ActionFrom是頁面有什麽值,類裏就寫什麽屬性,是用來封裝表單數據用的;而實體類是完全按照數據庫的字段生成的,實體類可以當做ActionFrom用,但ActionFrom絕對不可以當做實體類用),這樣表單數據就以ActionFrom對象的形式在Action的點擊“提交按鈕”執行的那個方法裏存在了。這個時候需要做的就是把表單數據存入數據庫中。此時,Action的功能告一段落,接著是把數據傳入BIZ層。

BIZE層(業務邏輯層):負責的是對數據的處理。如果沒有數據處理任務的話,此層只做單純的數據傳遞作用,而後又到了DAO層。

DAO層(數據庫操作層):負責對數據向數據庫增刪改查的操作。

在該註冊的框架中,如果不使用Spring的話,每個層之間的數據傳遞都需要new一個調用該層數據的類的實例。而使用了Spring的話,需要做的就是把DAO層和BIZ層的每個類都寫一個接口類,接口類裏寫實現類的方法,在調用的時候不new對象,直接用對象點(.)方法就可以,別忘了對每個對象加上set/get方法。


Action、Dao、Service三層的功能劃分