java四層架構(gòu) java異常從業(yè)務(wù)層集中拋出,是不是每個控制層方法都要trycatch?
java異常從業(yè)務(wù)層集中拋出,是不是每個控制層方法都要trycatch?在控制層有兩種異常:一種是預(yù)期的,另一種是可預(yù)測的。這種異常需要捕獲并“嘗試修復(fù)”。例如,在查詢用戶信息RPC的過程中,存在異常
java異常從業(yè)務(wù)層集中拋出,是不是每個控制層方法都要trycatch?
在控制層有兩種異常:一種是預(yù)期的,另一種是可預(yù)測的。這種異常需要捕獲并“嘗試修復(fù)”。例如,在查詢用戶信息RPC的過程中,存在異常,包括500ah和404ah。對于客戶端,基本上不需要重試,這可以通過一個明確的錯誤代碼來通知。相反,在超時的情況下,可以通知客戶端稍后再試,不同的錯誤代碼可以引導(dǎo)客戶端進行不同的操作。另一種情況是控制層本身不考慮。在這種情況下,盲目的嘗試/捕捉?jīng)]有多大意義。它通常在框架級進行統(tǒng)一處理,包括記錄異常信息和優(yōu)雅的返回失敗。
最后,對于try/catch的使用,我們并不意味著我們看不到異常,但我們更多地考慮捕獲后我可以做什么,以及我是否可以嘗試解決此問題。如果沒有,我們可以把它扔到上層,記錄并報警。如果我們不把這個問題想清楚,就很容易形成一個禁忌(吞下例外)。
java業(yè)務(wù)邏輯,寫在哪里比較好?
現(xiàn)在很多公司的開發(fā)人員都應(yīng)該采用MVC架構(gòu)。
MVC是所謂的模型、視圖、控制器。
每一層都有明確的分工。
對于簡單的項目,不管nignx如何,網(wǎng)關(guān)通常都會將請求從前端發(fā)送到后端,首先發(fā)送到控制器,然后發(fā)送到服務(wù)層,然后發(fā)送到Dao層。
這里的服務(wù)層就是所謂的業(yè)務(wù)層,專門負責(zé)業(yè)務(wù)處理操作,而Dao層則負責(zé)處理數(shù)據(jù)庫,將數(shù)據(jù)庫中的數(shù)據(jù)帶回服務(wù),經(jīng)過服務(wù)處理后返回控制器層??刂破魍ㄟ^視圖解析器解析頁面,并通過瀏覽器呈現(xiàn)頁面。
基本上,我認為答案是顯而易見的。也就是說,Java業(yè)務(wù)邏輯是在服務(wù)層編寫的。
事實上,服務(wù)層涉及接口和接口實現(xiàn)。
在編寫代碼時,我們通常為控制器定義一個調(diào)用接口。
實際上,服務(wù)接口的實現(xiàn)類應(yīng)該是編寫業(yè)務(wù)邏輯的地方。
當(dāng)然,許多公司可能有多個服務(wù)層,例如,有一個管理層繼續(xù)對數(shù)據(jù)進行特殊的業(yè)務(wù)處理。這里只是一個簡單的概述。
每個公司的每個項目根據(jù)其自身業(yè)務(wù)可能有不同的體系結(jié)構(gòu)。但本質(zhì)是一樣的。
綜上所述,業(yè)務(wù)邏輯必須作為一個獨立的層來處理,這樣便于擴展和維護。記住不要在控制器中編寫所有業(yè)務(wù)邏輯。
每一層都有自己的分工,是捏合在一起的。代碼不僅冗長,而且雜亂無章。
我希望我能幫助你
!如果你有興趣,可以關(guān)注一下,一起學(xué)習(xí)交流
如何學(xué)會Java框架?
謝謝。準(zhǔn)備學(xué)習(xí)Java框架意味著你已經(jīng)有了在Java基礎(chǔ)上學(xué)習(xí)的經(jīng)驗。此時,堅實的基礎(chǔ)可以決定框架的學(xué)習(xí)速度。
Java框架,在學(xué)校里,可能主要以SSH為例,即spring、struts和herbnate。但事實上,SSM更多的是在工作中使用,即spring、springmvc和mybatis。
最重要的部分是spring,因為公司后續(xù)工作中使用的SSM和springboot都是基于spring框架的集成框架。
因此,主框架是spring,其次是數(shù)據(jù)持久層框架,最好是mybatis,然后控制層框架是spring MVC。
學(xué)習(xí)資料可以是博客,最好的官方文件。
學(xué)習(xí)視頻可以去淘寶網(wǎng)花幾元錢買,沒有損失。