溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

web三層架構(gòu)工作原理是什么

發(fā)布時間:2021-12-07 17:53:26 來源:億速云 閱讀:244 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要講解了“web三層架構(gòu)工作原理是什么”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“web三層架構(gòu)工作原理是什么”吧!

一、什么是三層架構(gòu)

三層架構(gòu)就是為了符合“高內(nèi)聚,低耦合”思想,把各個功能模塊劃分為表示層(UI)、業(yè)務(wù)邏輯層(BLL)和 數(shù)據(jù)訪問層(DAL)三層架構(gòu),各層之間采用接口相互訪問,并通過對象模型的實體類(Model)作為數(shù)據(jù)傳遞的載體,不同的對象模型的實體類一般對應(yīng)于數(shù)據(jù)庫的不同表,實體類的屬性與數(shù)據(jù)庫表的字段名一致。

各模塊功能劃分表:

UI(表現(xiàn)層)主要是指與用戶交互的界面。用于接收用戶輸入的數(shù)據(jù)和顯示處理后用戶需要的數(shù)據(jù)。
BLL:(業(yè)務(wù)邏輯層)UI層和DAL層之間的橋梁。實現(xiàn)業(yè)務(wù)邏輯。業(yè)務(wù)邏輯具體包含:驗證、計算、業(yè)務(wù)規(guī)則等等。
DAL:(數(shù)據(jù)訪問層)與數(shù)據(jù)庫打交道。主要實現(xiàn)對數(shù)據(jù)的增、刪、改、查。將存儲在數(shù)據(jù)庫中的數(shù)據(jù)提交給業(yè)務(wù)層,同時將業(yè)務(wù)層處理的數(shù)據(jù)保存到數(shù)據(jù)庫。(當(dāng)然這些操作都是基于UI層的。用戶的需求反映給界面(UI),UI反映給BLL,BLL反應(yīng)給DAL,DAL進行數(shù)據(jù)的操作,操作后再逐步返回,直到將用戶所需數(shù)據(jù)反饋給用戶)

三層架構(gòu)運作流程圖:

web三層架構(gòu)工作原理是什么

三層架構(gòu)中各功能模塊如何聯(lián)系?

這里就要提到Entity(實體層):它不屬于三層中的任何一層,但是它是必不可少的一層。對于大量的數(shù)據(jù)來說,用變量做參數(shù)有些復(fù)雜,因為參數(shù)量太多,容易搞混。比如:我要把員工信息傳遞到下層,信息包括:員工號、姓名、年齡、性別、工資.......用變量做參數(shù)的話,那么我們的方法中的參數(shù)就會很多,極有可能在使用時,將參數(shù)匹配搞混。這時候,如果用實體做參數(shù),就會很方便,不用考慮參數(shù)匹配的問題,用到實體中哪個屬性拿來直接用就可以,很方便。這樣做也提高了效率。

Entity在三層架構(gòu)中的作用:

1.實現(xiàn)面向?qū)ο笏枷胫械?quot;封裝";
2.貫穿于三層,在三層之間傳遞數(shù)據(jù);(注:確切的說實體層貫穿于三層之間,來連接三層)

3.對于初學(xué)者來說,可以這樣理解:

每張數(shù)據(jù)表對應(yīng)一個實體,即每個數(shù)據(jù)表中的字段對應(yīng)實體中的屬性

(注:當(dāng)然,事實上不是這樣。

         為什么?

        1>)可能我們需要的實體在數(shù)據(jù)表對應(yīng)的實體中并不存在

        2>)我們完全可以將所有數(shù)據(jù)表中的所有字段都放在一個實體里)

4.每一層(UI—>BLL—>DAL)之間的數(shù)據(jù)傳遞(單向)是靠變量或?qū)嶓w作為參數(shù)來傳遞的,這樣就構(gòu)造了三層之間的聯(lián)系,完成了功能的實現(xiàn)。

(補充:3.中為什么說可以暫時理解為每個數(shù)據(jù)表對應(yīng)一個實體??

我們做系統(tǒng)的目的,是為用戶提供服務(wù),用戶可不關(guān)心你的系統(tǒng)后臺是怎么工作的,用戶只關(guān)心軟件是不是好用,界面是不是符合自己心意。用戶在界面上輕松的增、刪、改、查,那么數(shù)據(jù)庫中也要有相應(yīng)的增、刪、改、查,而增刪改查具體操作對象就是數(shù)據(jù)庫中的數(shù)據(jù),說白了就是表中的字段。所以,將每個數(shù)據(jù)表作為一個實體類,實體類封裝的屬性對應(yīng)到表中的字段,這樣的話,實體在貫穿于三層之間時,就可以實現(xiàn)增刪改查數(shù)據(jù)了)

 三層及實體層之間的依賴關(guān)系:

web三層架構(gòu)工作原理是什么

二、為什么使用三層架構(gòu)

三層架構(gòu)區(qū)分層次的目的是為了 “高內(nèi)聚,低耦合”。開發(fā)人員分工更明確,將精力更專注于應(yīng)用系統(tǒng)核心業(yè)務(wù)邏輯的分析、設(shè)計和開發(fā),加快項目的進度,提高了開發(fā)效率,有利于項目的更新和維護工作。

三、三層與兩層的區(qū)別

兩層:

web三層架構(gòu)工作原理是什么

(當(dāng)任何一個地方發(fā)生變化時,都需要重新開發(fā)整個系統(tǒng)。"多層"放在一層,分工不明確耦合度高——難以適應(yīng)需求變化,可維護性低、可擴展性低)

三層:

web三層架構(gòu)工作原理是什么

(發(fā)生在哪一層的變化,只需更改該層,不需要更改整個系統(tǒng)。層次清晰,分工明確,每層之間耦合度低——提高了效率,適應(yīng)需求變化,可維護性高,可擴展性高)

三層架構(gòu)的優(yōu)勢:

1.結(jié)構(gòu)清晰、耦合度低
2.可維護性高,可擴展性高
3.利于開發(fā)任務(wù)同步進行, 容易適應(yīng)需求變化

三層架構(gòu)的劣勢:

1.降低了系統(tǒng)的性能。這是不言而喻的。如果不采用分層式結(jié)構(gòu),很多業(yè)務(wù)可以直接造訪數(shù)據(jù)庫,以此獲取相應(yīng)的數(shù)據(jù),如今卻必須通過中間層來完成。
2.有時會導(dǎo)致級聯(lián)的修改。這種修改尤其體現(xiàn)在自上而下的方向。如果在表示層中需要增加一個功能,為保證其設(shè)計符合分層式結(jié)構(gòu),可能需要在相應(yīng)的業(yè)務(wù)邏輯層和數(shù)據(jù)訪問層中都增加相應(yīng)的代碼
3.增加了代碼量,增加了工作量

感謝各位的閱讀,以上就是“web三層架構(gòu)工作原理是什么”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對web三層架構(gòu)工作原理是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

web
AI