天天看點

Java中Action層、Service層、Modle層和Dao層的功能區分

一、Java中Action層、Service層、Modle層和Dao層的功能區分:

  首先,這是現在最基本的分層方式,結合了SSH架構。

  modle層就是對應的資料庫表的實體類。(即domain)

  Dao層是使用了hibernate連接配接資料庫、操作資料庫(增删改查)。

  Service層:引用對應的Dao資料庫操作,在這裡可以編寫自己需要的代碼(比如簡單的判斷)。

  Action層:引用對應的Service層,在這裡結合Struts的配置檔案,跳轉到指定的頁面,當然也能接受頁面傳遞的請求資料,也可以做些計算處理。

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

  一般Java都是三層架構:資料通路層(dao)、業務邏輯層(biz 或者services)、界面層(ui) :

  action 是業務層的一部分,是一個管理器 (總開關)(作用是取調轉)(取出前台界面的資料,調用biz方法,轉發到下一個action或者頁面)。

  模型層(model)一般是實體對象(把現實的的事物變成java中的對象),作用是暫時存儲資料,友善持久化(存入資料庫或者寫入檔案),作為一個包裹封裝一些資料來在不同的層以及各種java對象中使用。

  dao是資料通路層,就是用來通路資料庫實作資料的持久化(把記憶體中的資料永久儲存到硬碟中)。

  Dao主要做資料庫的互動工作;

  Modle 是模型,存放你的實體類;

  Service做相應的業務邏輯處理;

  Action是一個控制器。

  首先解釋面上意思,service是業務層,dao是資料通路層。呵呵,這個問題我曾經也有過,記得以前剛學程式設計的時候,都是在service裡直接調用dao,service裡面就new一個dao類對象,調用,其他有意義的事沒做,也不明白有這個有什麼用,參加工作久了以後就會知道,業務才是工作中的重中之重。我們都知道,标準主流現在的程式設計方式都是采用MVC綜合設計模式,MVC本身不屬于設計模式的一種,它描述的是一種結構,最終目的達到解耦,解耦說的意思是你更改某一層代碼,不會影響我其他層代碼,如果你會像spring這樣的架構,你會了解面向接口程式設計:表示層調用控制層,控制層調用業務層,業務層調用資料通路層。初期也許都是new對象去調用下一層,比如你在業務層new一個DAO類的對象,調用DAO類方法通路資料庫,這樣寫是不對的,因為在業務層中是不應該含有具體對象,最多隻能有引用,如果有具體對象存在,就耦合了。當那個對象不存在,我還要修改業務的代碼,這不符合邏輯。好比主機闆上記憶體壞了,我換記憶體,沒必要連主機闆一起換。我不用知道記憶體是哪家生産,不用知道多大容量,隻要是記憶體都可以插上這個接口使用。這就是MVC的意義。

  接下來說你感覺service的意義,其實因為你現在做東西分層次不是那麼嚴格,再一個你們做東西業務本身也少,舉個最簡單的例子,你做一個分頁的功能,資料1000條,你20條在一個頁,你可以把這個功能寫成工具類封裝起來,然後在業務層裡調用這個封裝的方法,這才是業務裡真正幹得事,隻要沒通路資料庫的,都要在業務裡寫。 再有不明白的追問,這是經驗問題,呵呵,其實以後你就會懂。隻是剛開始寫的代碼都是有個請求,我就去資料庫取,業務幾乎沒有。

  怎麼說呢,我不是理論帝。是以我講講自己的了解。比說你現在用的是SSH架構,做一個使用者子產品:

  1、假設現在你做這個功能會用到user表和權限表,那麼你前台的頁面通路action,action再去調用使用者子產品service,使用者子產品service判斷你是操作user表還是權限表,如果你操作的是user表則service的實作類就去調用userDAO。如果是操作的是權限表則調用權限的DAO。

  2、也就是說DAO一定是和資料庫的每張表一一對應,而service則不是。明白的沒?其實你一個項目一個service和一個DAO其實也一樣可以操作資料庫,隻不過那要是表非常多,出問題了,那找起來多麻煩,而且太亂了。

  3、好處就是你的整個項目非常系統化,和資料庫的表能一緻,而且功能子產品化,這樣以後維護或者改錯比較容易,性能也高一些。

  簡單的說,DAO層是跟資料庫打交道的,service層是處理一些業務流程的,至于你說的為什麼要用service層封裝,我認為:一般來說,某一個程式的有些業務流程需要連接配接資料庫,有些不需要與資料庫打交道而直接是一些業務處理,這樣就需要我們整合起來到service中去,這樣可以起到一個更好的開發與維護的作用,同時也是MVC設計模式中model層功能的展現最基本的分層方式,結合了SSH架構。

  modle層就是對應的資料庫表的實體類(如User類)。Dao層,一般可以再分為***Dao接口和***DaoImpl實作類,如userDao接口和userDaoImpl實作類,接口負責定義資料庫curd的操作方法,實作類負責具體的實作,即實作Dao接口定義的方法。DAO隻完成增删改查,雖然可以1-n,n-n,1-1關聯,模糊、動态、子查詢都可以。但是無論多麼複雜的查詢,dao隻是封裝增删改查。至于增删查改如何去實作一個功能,dao是不管的。

  Service層:管理具體的功能:引用對應的Dao層資料庫操作,在這裡可以編寫自己需要的代碼(比如簡單的判斷),也可以再細分為Service接口和ServiceImpl實作類。

  Action層:管理業務(Service)排程和管理跳轉:引用對應的Service層實作業務邏輯,在這裡結合Struts的配置檔案,跳轉到指定的頁面,當然也能接受頁面傳遞的請求資料,也可以做些計算處理、前端輸入合法性檢驗(前端可修改網頁繞過前端合法性檢驗,需在背景加一層)。Action像是服務員,顧客點什麼菜,菜上給幾号桌,都是ta的職責;Service是廚師,action送來的菜單上的菜全是ta做的;Dao是廚房的小工和原材料(通過hibernate操作資料庫)打交道的事情全是ta管。

  對象的調用流程:JSP—Action—Service—DAO—Hibernate—資料庫。

Java中Action層、Service層、Modle層和Dao層的功能區分

二、何時使用.do和.jsp:

  在MVC的項目中一般不會直接去通路JSP,都是通過.do來轉發。這樣做的好處是:

  1、所有請求全部通過action來轉發,這樣便于整體架構的處理。比如,可以加入登陸到某個頁面的權限控制,隻需要在配置檔案中配置,而不用再每個JSP檔案中加入相關的邏輯。

  2、與資料庫、檔案等底層存儲層連接配接,讀取資料的代碼可以在類(action)中執行。這樣做一方面可以将很多方法複用,另一方面使JSP頁面的代碼變得簡單而容易維護。

  3、其實.do也就是MVC當中的C、是控制器。在整個系統中起到中央樞紐的作用。先通過它的話就可以把邏輯代碼隐藏在背景,使JSP檔案作為單純的VIEW分離出來,降低了系統的耦合性。

  問1:比如說regist.do對應的就是regist.jsp這個頁面,通過網頁可能所有的跳轉都是跳到regist.do去注冊,但實際上直接輸入regist.jsp應該也是可以打開一樣的頁面去注冊。

  回答:沒錯,的确是可以的。不過這樣做的話擴充性就沒有先經過.do那樣好。比如以後系統裡加入了新的要求,隻有權限大于5的人才能進入這個頁面。直接通路.jsp的方法的話,要在jsp裡加入判斷的代碼,如果權限小于5的話跳轉到其他畫面;不過如果隻是這一張頁面還好,但是如果系統有200張jsp,而且每張jsp要求的權限都不一樣的話,這樣修改起來就很困難了。用.do轉發的方法的話,可以在配置檔案中配置通路每個action所需要的權限,然後在系統的中央處理器(servlet)裡面加入一個判斷,去校驗每個使用者的session,從裡面取得目前使用者的權限并且與action的需要權限相對比,如果不比對就直接跳到其他頁面。這樣不管整個系統有多少張頁面,隻要有這個配置,當使用者需求發生變化時隻要改改配置檔案就可以完成任務了。