化繁就簡搅方,如何利用Spring AOP快速實現(xiàn)系統(tǒng)日志

1、引言

有關(guān)Spring AOP的概念就不細(xì)講了绽族,網(wǎng)上這樣的文章一大堆姨涡,要講我也不會比別人講得更好,所以就不啰嗦了吧慢。

為什么要用Spring AOP呢涛漂?少寫代碼專注自身業(yè)務(wù)邏輯實現(xiàn)(關(guān)注本身的業(yè)務(wù)而不去想其它事情,如安全匈仗、事務(wù)瓢剿、日志等),用點上檔次的話說:通過非侵入式的方式實現(xiàn)我們要實現(xiàn)的功能悠轩。

我們?yōu)槭裁匆肧pring AOP來實現(xiàn)系統(tǒng)日志呢间狂?系統(tǒng)日志的特點是在系統(tǒng)的多個模塊中都要用到,為了實現(xiàn)日志的統(tǒng)一管理火架,我們一般有以下三種做法:

  1. 定義日志實現(xiàn)類鉴象,在需要記錄日志的地方創(chuàng)建實例來進(jìn)行調(diào)用;
  2. 定義一個日志接口及實現(xiàn)類何鸡,要用到日志的地方繼承該接口(為什么是要定義接口纺弊,而不是直接定義類,是因為接口能夠?qū)崿F(xiàn)多繼承骡男,而我們的后臺類中有不少本身就是要繼承相應(yīng)的接口的淆游,這樣不會因為日志接口的引入而影響我們其他的業(yè)務(wù)實現(xiàn));
  3. 引入Spring AOP隔盛,面向切面編程稽犁,非侵入式的實現(xiàn)日志功能。

分析以上三種方式骚亿,都可以實現(xiàn)系統(tǒng)日志功能:

  • 但第1種太繁瑣了已亥,搞得到處都是,不好看啊来屠,也顯得low虑椎;
  • 第2種雖然不像第1種一樣,但要記錄日志就非得繼承接口俱笛,還得進(jìn)行一系列的調(diào)用方法捆姜、傳遞參數(shù),總覺得額外增加了好多的累贅迎膜;
  • 第3種泥技,還不賴,只需在要記錄日志的方法上添加一個注解就行了磕仅,能夠記錄的動態(tài)日志內(nèi)容(區(qū)別于網(wǎng)上好多文章介紹的內(nèi)容珊豹,記錄的都是靜態(tài)內(nèi)容,簡單是簡單榕订,了店茶,但不實用啊)可以相當(dāng)豐富劫恒,代碼好干凈贩幻,看著就爽轿腺。

2、Spring AOP實現(xiàn)系統(tǒng)日志要幾步丛楚?

把大象裝冰箱要幾步族壳?第一步打開冰箱,第二步把大象裝進(jìn)去趣些,第三步關(guān)上冰箱門仿荆,齊活。
同樣喧务,Spring AOP實現(xiàn)系統(tǒng)日志要幾步呢赖歌?

第一步自定義注解類;
第二步定義切面類功茴;
第三步在普通類中的方法上加入自定義日志注解庐冯,齊活。
下面一張圖說明:

Image.png

理解了上面的圖坎穿,您就已經(jīng)可以利用Spring AOP來實現(xiàn)您自己的系統(tǒng)日志了展父。

系統(tǒng)日志一般保存在數(shù)據(jù)庫里面,以方便管理人員的瀏覽查詢玲昧。另外我們需要做到不同的操作類型要記錄不同的內(nèi)容栖茉,如增加或刪除了數(shù)據(jù),那么要記錄增加或刪除的詳細(xì)信息孵延,如果做了修改吕漂,日志要能記錄修改前后的值,等等尘应,這些工作都在第二步定義切面類中實現(xiàn)惶凝。

有關(guān)詳盡的代碼,大家可以參考我的視頻:https://edu.51cto.com/sd/091c7 犬钢,這里就不詳細(xì)貼出來了

3苍鲜、Spring AOP必要知識點

雖然說我不想講解Spring AOP的概念,但必要的概念大家還是要清楚的玷犹,否則就會云山霧罩混滔,照貓畫虎可能畫的都會不像。

對于下面Spring AOP的概念歹颓,我盡量講人話:

連接點(JoinPoint):方法的前面坯屿、后面以及異常都是連接點,應(yīng)用時的類為ProceedingJoinPoint晴股;
切入點(Pointcut):就是在方法前面愿伴、還是后面或者是前后都織入,對應(yīng)注解:@Before电湘、@After、@Around;
織入(weaving):就是在方法前面寂呛、還是后面或者是前后都織入怎诫;對應(yīng)注解:@Retention,包括三種類型贷痪,SOURCE幻妓、CLASS、RUNTIME劫拢、指明注解的生命周期肉津,一般采用RUNTIME(運行時注解);
目標(biāo)(target):向方法上添加新方法屬性舱沧,對應(yīng)注解:@Target妹沙;
切面(aspect):具體干活的類,對應(yīng)注解:@Aspect熟吏;

另外還有代理(proxy)距糖、通知(Advice)、引入(introduction)這三個概念牵寺,也就是三個概念悍引,便于你更好的理解AOP機(jī)制。(不太恰當(dāng)帽氓,好比面向?qū)ο缶幊倘そ铮鸵斫夥庋b、繼承和多態(tài)一樣)黎休,理解最好浓领,不理解也不會太影響您工作的開展。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末奋渔,一起剝皮案震驚了整個濱河市镊逝,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌嫉鲸,老刑警劉巖撑蒜,帶你破解...
    沈念sama閱讀 218,755評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異玄渗,居然都是意外死亡座菠,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評論 3 395
  • 文/潘曉璐 我一進(jìn)店門藤树,熙熙樓的掌柜王于貴愁眉苦臉地迎上來浴滴,“玉大人,你說我怎么就攤上這事岁钓∩裕” “怎么了微王?”我有些...
    開封第一講書人閱讀 165,138評論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀的道長品嚣。 經(jīng)常有香客問我炕倘,道長,這世上最難降的妖魔是什么翰撑? 我笑而不...
    開封第一講書人閱讀 58,791評論 1 295
  • 正文 為了忘掉前任罩旋,我火速辦了婚禮,結(jié)果婚禮上眶诈,老公的妹妹穿的比我還像新娘涨醋。我一直安慰自己,他們只是感情好逝撬,可當(dāng)我...
    茶點故事閱讀 67,794評論 6 392
  • 文/花漫 我一把揭開白布浴骂。 她就那樣靜靜地躺著,像睡著了一般球拦。 火紅的嫁衣襯著肌膚如雪靠闭。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,631評論 1 305
  • 那天坎炼,我揣著相機(jī)與錄音愧膀,去河邊找鬼。 笑死谣光,一個胖子當(dāng)著我的面吹牛檩淋,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播萄金,決...
    沈念sama閱讀 40,362評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼蟀悦,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了氧敢?” 一聲冷哼從身側(cè)響起日戈,我...
    開封第一講書人閱讀 39,264評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎孙乖,沒想到半個月后浙炼,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,724評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡唯袄,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年弯屈,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片恋拷。...
    茶點故事閱讀 40,040評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡资厉,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出蔬顾,到底是詐尸還是另有隱情宴偿,我是刑警寧澤湘捎,帶...
    沈念sama閱讀 35,742評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站酪我,受9級特大地震影響消痛,放射性物質(zhì)發(fā)生泄漏且叁。R本人自食惡果不足惜都哭,卻給世界環(huán)境...
    茶點故事閱讀 41,364評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望逞带。 院中可真熱鬧欺矫,春花似錦、人聲如沸展氓。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,944評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽遇汞。三九已至未妹,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間空入,已是汗流浹背络它。 一陣腳步聲響...
    開封第一講書人閱讀 33,060評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留歪赢,地道東北人化戳。 一個月前我還...
    沈念sama閱讀 48,247評論 3 371
  • 正文 我出身青樓,卻偏偏與公主長得像埋凯,于是被迫代替她去往敵國和親点楼。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,979評論 2 355

推薦閱讀更多精彩內(nèi)容