化繁就簡,如何利用Spring AOP快速實現系統日誌

1、引言

有關Spring AOP的概念就不細講了,網上這樣的文章一大堆,要講我也不會比別人講得更好,所以就不囉嗦了。

爲什麼要用Spring AOP呢?少寫代碼專注自身業務邏輯實現(關注本身的業務而不去想其它事情,如安全、事務、日誌等),用點上檔次的話說:通過非侵入式的方式實現我們要實現的功能

我們爲什麼要用Spring AOP來實現系統日誌呢?系統日誌的特點是在系統的多個模塊中都要用到,爲了實現日誌的統一管理,我們一般有以下三種做法:

  1. 定義日誌實現類,在需要記錄日誌的地方創建實例來進行調用;
  2. 定義一個日誌接口及實現類,要用到日誌的地方繼承該接口(爲什麼是要定義接口,而不是直接定義類,是因爲接口能夠實現多繼承,而我們的後臺類中有不少本身就是要繼承相應的接口的,這樣不會因爲日誌接口的引入而影響我們其他的業務實現);
  3. 引入Spring AOP,面向切面編程,非侵入式的實現日誌功能。

分析以上三種方式,都可以實現系統日誌功能:

  • 但第1種太繁瑣了,搞得到處都是,不好看啊,也顯得low;
  • 第2種雖然不像第1種一樣,但要記錄日誌就非得繼承接口,還得進行一系列的調用方法、傳遞參數,總覺得額外增加了好多的累贅;
  • 第3種,還不賴,只需在要記錄日誌的方法上添加一個註解就行了,能夠記錄的動態日誌內容(區別於網上好多文章介紹的內容,記錄的都是靜態內容,簡單是簡單,了,但不實用啊)可以相當豐富,代碼好乾淨,看着就爽。

2、Spring AOP實現系統日誌要幾步?

把大象裝冰箱要幾步?第一步打開冰箱,第二步把大象裝進去,第三步關上冰箱門,齊活。
同樣,Spring AOP實現系統日誌要幾步呢?

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

化繁就簡,如何利用Spring AOP快速實現系統日誌

理解了上面的圖,您就已經可以利用Spring AOP來實現您自己的系統日誌了。

系統日誌一般保存在數據庫裏面,以方便管理人員的瀏覽查詢。另外我們需要做到不同的操作類型要記錄不同的內容,如增加或刪除了數據,那麼要記錄增加或刪除的詳細信息,如果做了修改,日誌要能記錄修改前後的值,等等,這些工作都在第二步定義切面類中實現。

有關詳盡的代碼,大家可以參考我的視頻:https://edu.51cto.com/sd/091c7 ,這裏就不詳細貼出來了

3、Spring AOP必要知識點

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

對於下面Spring AOP的概念,我儘量講人話:

連接點(JoinPoint):方法的前面、後面以及異常都是連接點,應用時的類爲ProceedingJoinPoint;
切入點(Pointcut):就是在方法前面、還是後面或者是前後都織入,對應註解:@Before、@After、@Around;
織入(weaving):就是在方法前面、還是後面或者是前後都織入;對應註解:@Retention,包括三種類型,SOURCE、CLASS、RUNTIME、指明註解的生命週期,一般採用RUNTIME(運行時註解);
目標(target):向方法上添加新方法屬性,對應註解:@Target;
切面(aspect):具體幹活的類,對應註解:@Aspect;

另外還有代理(proxy)、通知(Advice)、引入(introduction)這三個概念,也就是三個概念,便於你更好的理解AOP機制。(不太恰當,好比面向對象編程,就要理解封裝、繼承和多態一樣),理解最好,不理解也不會太影響您工作的開展。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章