java編程 在Javaweb中如何體現(xiàn)三層架構(gòu)思想?
在Javaweb中如何體現(xiàn)三層架構(gòu)思想?一個(gè)非常好的問題。三層或多層體系結(jié)構(gòu)的核心思想是分層,不同的粒度和維度有不同的應(yīng)用。動(dòng)靜分離、數(shù)據(jù)中心和微服務(wù)的共同存在,在一定程度上使系統(tǒng)實(shí)現(xiàn)層層解耦,使系統(tǒng)
在Javaweb中如何體現(xiàn)三層架構(gòu)思想?
一個(gè)非常好的問題。三層或多層體系結(jié)構(gòu)的核心思想是分層,不同的粒度和維度有不同的應(yīng)用。
動(dòng)靜分離、數(shù)據(jù)中心和微服務(wù)的共同存在,在一定程度上使系統(tǒng)實(shí)現(xiàn)層層解耦,使系統(tǒng)表現(xiàn)在不同的層次上,如典型的前端頁面顯示、接口服務(wù)和數(shù)據(jù)存儲(chǔ)。
以典型的螞蟻設(shè)計(jì)開發(fā)信息管理系統(tǒng)為例,將前端實(shí)現(xiàn)分為三層:頁面、模型和服務(wù)。頁面顯示對(duì)用戶操作的頁面響應(yīng),模型保存數(shù)據(jù),服務(wù)處理業(yè)務(wù)邏輯并調(diào)用后端服務(wù)接口。
在后端開發(fā)中,仍將使用分層體系結(jié)構(gòu)。例如,在用JavaSpringBoot框架開發(fā)web服務(wù)時(shí),將控制器、服務(wù)和實(shí)體分別封裝起來
我是一位工作多年的web應(yīng)用程序架構(gòu)師。請(qǐng)關(guān)注我,多了解it專業(yè)知識(shí)。
java業(yè)務(wù)邏輯,寫在哪里比較好?
現(xiàn)在很多公司的開發(fā)人員都應(yīng)該采用MVC架構(gòu)。
MVC是所謂的模型、視圖、控制器。
每一層都有明確的分工。
對(duì)于簡(jiǎn)單的項(xiàng)目,不管nignx如何,網(wǎng)關(guān)通常都會(huì)將請(qǐng)求從前端發(fā)送到后端,首先發(fā)送到控制器,然后發(fā)送到服務(wù)層,然后發(fā)送到Dao層。
這里的服務(wù)層就是所謂的業(yè)務(wù)層,專門負(fù)責(zé)業(yè)務(wù)處理操作,而Dao層則負(fù)責(zé)處理數(shù)據(jù)庫,將數(shù)據(jù)庫中的數(shù)據(jù)帶回服務(wù),經(jīng)過服務(wù)處理后返回控制器層??刂破魍ㄟ^視圖解析器解析頁面,并通過瀏覽器呈現(xiàn)頁面。
基本上,我認(rèn)為答案是顯而易見的。也就是說,Java業(yè)務(wù)邏輯是在服務(wù)層編寫的。
事實(shí)上,服務(wù)層涉及接口和接口實(shí)現(xiàn)。
在編寫代碼時(shí),我們通常為控制器定義一個(gè)調(diào)用接口。
實(shí)際上,服務(wù)接口的實(shí)現(xiàn)類應(yīng)該是編寫業(yè)務(wù)邏輯的地方。
當(dāng)然,許多公司可能有多個(gè)服務(wù)層,例如,有一個(gè)管理層繼續(xù)對(duì)數(shù)據(jù)進(jìn)行特殊的業(yè)務(wù)處理。這里只是一個(gè)簡(jiǎn)單的概述。
每個(gè)公司的每個(gè)項(xiàng)目根據(jù)其自身業(yè)務(wù)可能有不同的體系結(jié)構(gòu)。但本質(zhì)是一樣的。
綜上所述,業(yè)務(wù)邏輯必須作為一個(gè)獨(dú)立的層來處理,這樣便于擴(kuò)展和維護(hù)。記住不要在控制器中編寫所有業(yè)務(wù)邏輯。
每一層都有自己的分工,是捏合在一起的。代碼不僅冗長(zhǎng),而且雜亂無章。
好吧,我希望我的回答能幫助你
!如果你有興趣,可以關(guān)注一下,一起學(xué)習(xí)交流
Java Web開發(fā)中,業(yè)務(wù)邏輯寫在SQL里好還是代碼里好呢?有什么建議嗎?
目前,大多數(shù)研發(fā)團(tuán)隊(duì)都要求用代碼實(shí)現(xiàn)業(yè)務(wù)邏輯,SQL操作往往是最基本的操作。用SQL表示業(yè)務(wù)邏輯,即用存儲(chǔ)過程表示業(yè)務(wù)邏輯,是一種傳統(tǒng)的開發(fā)方案。
在C/s時(shí)代,很多邏輯都是通過SQL來實(shí)現(xiàn)的,主要是因?yàn)闃I(yè)務(wù)規(guī)模和部署方式。在早期的C/s編程時(shí)代,它通常是在非分布式環(huán)境中開發(fā)的,在大多數(shù)情況下,它不需要考慮可移植性問題。這時(shí),使用SQL來完成業(yè)務(wù)邏輯就更方便了。
使用存儲(chǔ)過程來完成業(yè)務(wù)邏輯的最大優(yōu)點(diǎn)是性能會(huì)更好,但這也取決于業(yè)務(wù)的大小。如果業(yè)務(wù)規(guī)模過大,業(yè)績(jī)會(huì)更差。早期的數(shù)據(jù)存儲(chǔ)規(guī)模比較小,所以使用存儲(chǔ)過程比較方便。
當(dāng)前網(wǎng)絡(luò)發(fā)展已進(jìn)入大數(shù)據(jù)、云計(jì)算時(shí)代,業(yè)務(wù)類型和業(yè)務(wù)規(guī)模發(fā)生了巨大變化。特別是隨著NoSQL數(shù)據(jù)庫在大數(shù)據(jù)時(shí)代的廣泛應(yīng)用,使用SQL語句來完成業(yè)務(wù)邏輯的場(chǎng)景越來越少。而且,目前大多數(shù)程序都是分布式的,使用SQL存儲(chǔ)過程處理業(yè)務(wù)邏輯非常麻煩,會(huì)導(dǎo)致整個(gè)項(xiàng)目的可移植性和可讀性嚴(yán)重下降。
目前,在傳統(tǒng)企業(yè)的開發(fā)團(tuán)隊(duì)中,使用SQL來處理業(yè)務(wù)邏輯是相當(dāng)普遍的,因?yàn)閭鹘y(tǒng)企業(yè)的數(shù)據(jù)庫大多還是關(guān)系數(shù)據(jù)庫,沒有可移植性的要求。這種固定的場(chǎng)景開發(fā)可以使用SQL來處理業(yè)務(wù)邏輯。在將來,使用SQL處理業(yè)務(wù)邏輯時(shí)會(huì)出現(xiàn)一些應(yīng)用場(chǎng)景,因此有必要學(xué)習(xí)如何編寫存儲(chǔ)過程。