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