Java分層思想

 

 

 

 

 

 

從最常規的分層結構來講,系統層次從上到下依次爲:html

 

表現層/UI層/界面層:主要是客戶端的展現。java

 

服務層/業務層:直接爲客戶端提供的服務或功能。也是系統所能對外提供的功能。web

 

領域層:系統內的領域活動。spring

 

DAO層:數據訪問對象,經過領域實體對象來操做數據庫。數據庫

 

其中有些指導原則(精華):編程

 

一、上層老是依賴其下層,依賴關係不跨層。設計模式

二、表現層除外,同一層之間方法不容許相互調用。這是實際開發中一些開發者容易範的錯誤!若是真是同一層之間存在方法調用,須要注意,這些調用都是一些上層不可見方法,好比一些工具方法等。安全

三、一切從服務層出發,從系統須要提供的功能進行分析,肯定Service接口中的方法。而不是從數據庫的表出發,建立DAO,再創Domain,而後Service,這其實是對系統分層的誤解。架構

四、系統最核心的設計就是將系統中的實體劃分爲領域模型。在此基礎上設計數據的DAO層,並將這些活動暴露給服務層,服務層的實現依賴於領域活動。app

五、每一個接口的職責範圍明確有界。

 

service是業務層 

action層即做爲控制器

DAO (Data Access Object) 數據訪問

1.JAVA中Action層, Service層 ,modle層 和 Dao層的功能區分?(下面所描述的service層就是biz) 

首先這是如今最基本的分層方式,結合了SSH架構。modle層就是對應的數據庫表的實體類。

Dao層是使用了Hibernate鏈接數據庫、操做數據庫(增刪改查)。

Service(biz)層:引用對應的Dao數據庫操做,在這裏能夠編寫本身須要的代碼(好比簡單的判斷)。

Action層:引用對應的Service(biz)層,在這裏結合Struts的配置文件,跳轉到指定的頁面,固然也能接受頁面傳遞的請求數據,也能夠作些計算處理。

以上的Hibernate,Struts,都須要注入到Spring的配置文件中,Spring把這些聯繫起來,成爲一個總體。

其餘答案: 

  通常java都是三層架構 數據訪問層(dao) 業務邏輯層(biz 或者services) 界面層(ui) 

action 是業務層的一部分,是一個管理器 (總開關)(做用是取掉轉)(取出前臺界面的數據,調用biz方法,轉發到下一個action或者頁面)    

模型成(model)通常是實體對象(把現實的的事物變成java中的對象)做用是一暫時存儲數據方便持久化(存入數據庫或者寫入文件)而是 做爲一個包裹封裝一些數據來在不一樣的層以及各類java對象中使用   

dao是數據訪問層  就是用來訪問數據庫實現數據的持久化(把內存中的數據永久保存到硬盤中 其餘答案:  Action是一個控制器 Dao主要作數據庫的交互工做 Modle 是模型 存放你的實體類 Biz 作相應的業務邏輯處理    

2.java中dao層和biz層的區別是什麼? 

首先解釋面上意思,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層功能的體現  

3.java中的action是什麼,DAO又是什麼? 

Action類 是[得到Form表單數據,並處理邏輯的類]  

  DAO(Data Access Object) 是一個接口實現[經過SessionFactory得到操做數據庫的會話,並實現一些基本的刪除 添加 修改數據,在servlet中更實際化業務操做]  

4. 什麼是Pojo類? 

簡單的Java對象(Plain Old Java Objects)實際就是普通JavaBeans,使用POJO名稱是爲了不和EJB混淆起來, 並且簡稱比較直接. 其中有一些屬性及其getter setter方法的類,有時能夠做爲value object或dto(Data Transform Object)來使用.固然,若是你有一個簡單的運算屬性也是能夠的,但不容許有業務方法,也不能攜帶有connection之類的方法。  

5.pojo類和vo類分別是什麼 

vo有兩種說法,一個是viewObject,一個是valueObject..

  就拿前者來講吧,它只負責封裝頁面傳遞過來的數據,這和PO有些不一樣..

  就拿struts1來講,ActionForm就是一個典型的viewObject. 而valueObject是頁面與頁面之間的傳遞時保存值的對象....

  總的來講,PO是最終傳給BO以及BO傳個DAO的東西,他不少狀況下與咱們真正的數據庫表想對應.

  而viewObject是一個頁面上提交後的數據,不必定徹底和PO的屬性相同.... 

pojo與DTO的區別

ational Mapping(對象關係映射)的縮寫。通俗點講,就是將對象與關係數據庫綁定,用對象來表示關係數據。

在O/R Mapping的世界裏,有兩個基本的也是重要的東東須要瞭解,即VO,PO。

  VO,值對象(Value Object),PO,持久對象(Persisent Object),它們是由一組屬性和屬性的get和set方法組成。從結構上看,它們並無什麼不一樣的地方。但從其意義和本質上來看是徹底不一樣的。

1.VO是用new關鍵字建立,由GC回收的。 

  PO則是向數據庫中添加新數據時建立,刪除數據庫中數據時削除的。而且它只能存活在一個數據庫鏈接中,斷開鏈接即被銷燬。 

2.VO是值對象,精確點講它是業務對象,是存活在業務層的,是業務邏輯使用的,它存活的目的就是爲數據提供一個生存的地方。 

  PO則是有狀態的,每一個屬性表明其當前的狀態。它是物理數據的對象表示。使用它,可使咱們的程序與物理數據解耦,而且能夠簡化對象數據與物理數據之間的轉換。

3.VO的屬性是根據當前業務的不一樣而不一樣的,也就是說,它的每個屬性都一一對應當前業務邏輯所須要的數據的名稱。 
  PO的屬性是跟數據庫表的字段一一對應的。

PO對象須要實現序列化接口。

-------------------------------------------------

PO是持久化對象,它只是將物理數據實體的一種對象表示,爲何須要它?由於它能夠簡化咱們對於物理實體的瞭解和耦合,簡單地講,能夠簡化對象的數據轉換爲物理數據的編程。VO是什麼?它是值對象,準確地講,它是業務對象,是生活在業務層的,是業務邏輯須要瞭解,須要使用的,再簡單地講,它是概念模型轉換獲得的。 

首先說PO和VO吧,它們的關係應該是相互獨立的,一個VO能夠只是PO的部分,也能夠是多個PO構成,一樣也能夠等同於一個PO(固然我是指他們的屬性)。正由於這樣,PO獨立出來,數據持久層也就獨立出來了,它不會受到任何業務的干涉。又正由於這樣,業務邏輯層也獨立開來,它不會受到數據持久層的影響,業務層關心的只是業務邏輯的處理,至於怎麼存怎麼讀交給別人吧!不過,另一點,若是咱們沒有使用數據持久層,或者說沒有使用hibernate,那麼PO和VO也能夠是同一個東西,雖然這並很差。 

----------------------------------------------------

java的(PO,VO,TO,BO,DAO,POJO)解釋

PO(persistant object) 持久對象 

在o/r映射的時候出現的概念,若是沒有o/r映射,沒有這個概念存在了。一般對應數據模型(數據庫),自己還有部分業務邏輯的處理。能夠當作是與數據庫中的表相映射的java對象。最簡單的PO就是對應數據庫中某個表中的一條記錄,多個記錄能夠用PO的集合。PO中應該不包含任何對數據庫的操做。 

VO(value object) 值對象 

一般用於業務層之間的數據傳遞,和PO同樣也是僅僅包含數據而已。但應是抽象出的業務對象,能夠和表對應,也能夠不,這根據業務的須要.我的以爲同DTO(數據傳輸對象),在web上傳遞。 

TO(Transfer Object),數據傳輸對象

在應用程序不一樣tie(關係)之間傳輸的對象 

BO(business object) 業務對象 

從業務模型的角度看,見UML元件領域模型中的領域對象。封裝業務邏輯的java對象,經過調用DAO方法,結合PO,VO進行業務操做。 

POJO(plain ordinary java object) 簡單無規則java對象

純的傳統意義的java對象。就是說在一些Object/Relation Mapping工具中,可以作到維護數據庫表記錄的persisent object徹底是一個符合Java Bean規範的純Java對象,沒有增長別的屬性和方法。個人理解就是最基本的Java Bean,只有屬性字段及setter和getter方法!。 

DAO(data access object) 數據訪問對象 

是一個sun的一個標準j2ee設計模式,這個模式中有個接口就是DAO,它負持久層的操做。爲業務層提供接口。此對象用於訪問數據庫。一般和PO結合使用,DAO中包含了各類數據庫的操做方法。經過它的方法,結合PO對數據庫進行相關的操做。夾在業務邏輯與數據庫資源中間。配合VO, 提供數據庫的CRUD操做... 

O/R Mapper 對象/關係 映射   

定義好全部的mapping以後,這個O/R Mapper能夠幫咱們作不少的工做。經過這些mappings,這個O/R Mapper能夠生成全部的關於對象保存,刪除,讀取的SQL語句,咱們再也不須要寫那麼多行的DAL代碼了。 

實體Model(實體模式) 

DAL(數據訪問層) 

IDAL(接口層) 

DALFactory(類工廠) 

BLL(業務邏輯層) 

BOF     Business Object Framework       業務對象框架 

SOA     Service Orient Architecture     面向服務的設計 

EMF     Eclipse Model Framework         Eclipse建模框架

----------------------------------------

PO:全稱是persistant object持久對象,最形象的理解就是一個PO就是數據庫中的一條記錄。好處是能夠把一條記錄做爲一個對象處理,能夠方便的轉爲其它對象。

BO:全稱是business object:業務對象。主要做用是把業務邏輯封裝爲一個對象。這個對象能夠包括一個或多個其它的對象。
好比一個簡歷,有教育經歷、工做經歷、社會關係等等。

咱們能夠把教育經歷對應一個PO,工做經歷對應一個PO,社會關係對應一個PO。創建一個對應簡歷的BO對象處理簡歷,每一個BO包含這些PO。這樣處理業務邏輯時,咱們就能夠針對BO去處理。
VO :

value object值對象

ViewObject表現層對象

主要對應界面顯示的數據對象。對於一個WEB頁面,或者SWT、SWING的一個界面,用一個VO對象對應整個界面的值。
DTO :

Data Transfer Object數據傳輸對象

主要用於遠程調用等須要大量傳輸對象的地方。

好比咱們一張表有100個字段,那麼對應的PO就有100個屬性。

可是咱們界面上只要顯示10個字段,客戶端用WEB service來獲取數據,沒有必要把整個PO對象傳遞到客戶端,這時咱們就能夠用只有這10個屬性的DTO來傳遞結果到客戶端,這樣也不會暴露服務端表結構.到達客戶端之後,若是用這個對象來對應界面顯示,那此時它的身份就轉爲VO

POJO :

plain ordinary java object 簡單java對象,我的感受POJO是最多見最多變的對象,是一箇中間對象,也是咱們最常打交道的對象。

一個POJO持久化之後就是PO,直接用它傳遞、傳遞過程當中就是DTO,直接用來對應表示層就是VO

DAO:

data access object數據訪問對象

這個你們最熟悉,和上面幾個O區別最大,基本沒有互相轉化的可能性和必要。

主要用來封裝對數據庫的訪問。經過它能夠把POJO持久化爲PO,用PO組裝出來VO、DTO

-----------------------------------------------------------------

PO:persistant object持久對象,能夠當作是與數據庫中的表相映射的java對象。最簡單的PO就是對應數據庫中某個表中的一條記錄,多個記錄能夠用PO的集合。PO中應該不包含任何對數據庫的操做.                                                                                        

VO:value object值對象。一般用於業務層之間的數據傳遞,和PO同樣也是僅僅包含數據而已。但應是抽象出的業務對象,能夠和表對應,也能夠不,這根據業務的須要.我的以爲同DTO(數據傳輸對象),在web上傳遞. 

DAO:data access object數據訪問對象,此對象用於訪問數據庫。一般和PO結合使用,DAO中包含了各類數據庫的操做方法。經過它的方法,結合PO對數據庫進行相關的操做. 

BO:business object業務對象,封裝業務邏輯的java對象,經過調用DAO方法,結合PO,VO進行業務操做; POJO:plain ordinary java object 簡單無規則java對象,我我的以爲它和其餘不是一個層面上的東西,VO和PO應該都屬於它。

---------------------------------------------

VO:值對象、視圖對象

PO:持久對象

QO:查詢對象

DAO:數據訪問對象

DTO:數據傳輸對象

----------------------------------------

struts 裏的 ActionForm 就是個VO;

hibernate裏的 實體bean就是個PO,也叫POJO;

hibernate裏的Criteria 就至關於一個QO;

在使用hibernate的時候咱們會定義一些查詢的方法,這些方法寫在接口裏,能夠有不一樣的實現類.而這個接口就能夠說是個DAO.

我的認爲QO和DTO差很少.

----------------------------------------

PO或叫BO,與數據庫最接近的一層,是ORM中的O,基本上是數據庫字段對應BO中的一個屬性,爲了同步與安全性考慮,最好只給DAO或者Service調用,而不要用packcode,backingBean,或者BO調。

DAO,數據訪問層,把VO,backingBean中的對象能夠放入。。。。

DTO,不多用,基本放入到DAO中,只是起到過渡的做用。

QO,是把一些與持久性查詢操做與語句放入。。

VO,V層中用到的基本元素與方法等放其中。若是要其調用BO,則要作BO轉換VO,VO轉換BO操做。VO的好處是其頁面的元素屬性多於BO,可起到很好的做用。。。。

----------------------------------------

樓上的不對吧,PO是持久化對象。BO=business object—業務對象。

PO能夠嚴格對應數據庫表,一張表對映一個PO。

BO則是業務邏輯處理對象,個人理解是它裝滿了業務邏輯的處理,在業務邏輯複雜的應用中有用。

VO:value object值對象、view object視圖對象

PO:持久對象

QO:查詢對象

DAO:數據訪問對象——同時還有DAO模式

DTO:數據傳輸對象——同時還有DTO模式

總結

以上就是本文關於Java分層概念詳解的所有內容.

相關文章
相關標籤/搜索