前言
spring boot是基于spring的用來開發web應用的框架,功能與spring mvc有點類似,但是spring boot的一大特點就是需要的配置非常少。spring boot推薦convention over configuration,也就是約定大于配置,因此spring boot會幫你做許多自動的配置,并且spring boot使用的是java config,幾乎可以做到零xml文件配置。
假設現在有這樣一種場景,需要統計某個接口的處理耗時,我們可以使用aop來實現,aop為aspect oriented programming的縮寫,意為:面向切面編程,通過預編譯方式和運行期動態代理實現程序功能的統一維護的一種技術。在spring boot中使用aop也非常簡單,只需要一點簡單的配置即可。
需要使用aop的類
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
@restcontroller public class downloadcontroller { @autowired private xmldownloadservice downloadservice; @autowired private xmlfileclearservice clearservice; @requestmapping ( "/download" ) @timer public string download() throws exception { downloadservice.download(); clearservice.compress(); clearservice.clearall(); return "ok" ; } } |
這是一個使用@restcontroller注解的controller類,這個類會去下載一些xml文件,然后壓縮,最后刪除下載的xml文件。現在我們要統計整個處理過程的耗時,使用aop來實現。在download上使用了一個@timer注解,這是一個自定義的普通注解,用來標記這個方法作為一個切點。
aspect類
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
@aspect @component public class vipaspect { private static final logger logger = loggerfactory.getlogger(vipaspect. class ); private long start; //定義切點 @pointcut ( "@annotation(cn.magicwindow.mlink.content.annotation.timer)" ) public void timer(){} //在方法執行前執行 @before ( "timer()" ) public void before() { start = system.currenttimemillis(); } //在方法執行后執行 @after ( "timer()" ) public void after() { long now = system.currenttimemillis(); logger.info( "job took time {}s in summary" , (now - start) / 1000 ); } } |
這里使用了注解來標記切點,也可以直接按照方法名稱來定義,具體的使用方法可以參考官方文檔。
配置spring boot支持aop
1
2
3
4
|
@configuration @enableaspectjautoproxy public class config { } |
只需要使用@enableaspectjautoproxy注解開啟spring boot的aop支持即可。
最后,在調用download方法之后就會打印出本次處理的用時。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對服務器之家的支持。
原文鏈接:https://juejin.im/post/5b67b8a5f265da0f742f07f1