您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關如何正確的使用SpringBoot AOP 攔截器,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
常用用于實現攔截的有:Filter、HandlerInterceptor、MethodInterceptor
第一種Filter屬于Servlet提供的,后兩者是spring提供的,HandlerInterceptor屬于Spring MVC項目提供的,用來攔截請求,在MethodInterceptor之前執行。
實現一個HandlerInterceptor可以實現接口HandlerInterceptor,也可以繼承HandlerInterceptorAdapter類,兩種方法一樣。這個不在本文范圍,具體使用之前已經寫過SpringBoot的(SpringMVC的使用一樣,區別只是配置)
MethodInterceptor是AOP項目中的攔截器,它攔截的目標是方法,即使不是Controller中的方法。
實現MethodInterceptor攔截器大致也分為兩種,一種是實現MethodInterceptor接口,另一種利用Aspect的注解或配置。
關于實現MethodInterceptor接口的這種方法,還需要在配置文件中做配置,在SpringMVC中使用還可以,在SpringBoot中使用起來似乎沒有那么方便。
本文主要還是說Aspect注解方式,個人覺得這種方法才比較靈活,與配置與工程整個代碼都沒有耦合(你添加一個類,做幾個注解就可以用了,無需在其他地方再做什么),更易應用。
首先為你的SpringBoot項目添加maven依賴,讓其支持aop(其實就是自動引入aop需要的一些jar)
在pom.xml中添加依賴:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId> </dependency>
然后創建Aspect測試類:
package com.shanhy.sboot.aop; import org.aspectj.lang.JoinPoint; import org.aspectj.lang.annotation.After; import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Before; import org.springframework.core.annotation.Order; import org.springframework.stereotype.Component; @Aspect // FOR AOP @Order(-99) // 控制多個Aspect的執行順序,越小越先執行 @Component public class TestAspect { @Before("@annotation(test)")// 攔截被TestAnnotation注解的方法;如果你需要攔截指定package指定規則名稱的方法,可以使用表達式execution(...),具體百度一下資料一大堆 public void beforeTest(JoinPoint point, TestAnnotation test) throws Throwable { System.out.println("beforeTest:" + test.name()); } @After("@annotation(test)") public void afterTest(JoinPoint point, TestAnnotation test) { System.out.println("afterTest:" + test.name()); } }
這樣就完成了,然后創建一個Controller驗證一下:
@RestController @RequestMapping("/test") public class TestController { @TestAnnotation(name="abc") @RequestMapping("/show") public String show() { return "OK"; } @RequestMapping("/show2") public String show2() { return "OK2"; } }
此時我們訪問show請求,就會被攔截,控制臺會打印輸出。如果請求show2則不會被攔截。
注意:
1、在application.properties中也不需要添加spring.aop.auto=true,因為這個默認就是true,值為true就是啟用@EnableAspectJAutoProxy注解了。
2、你不需要手工添加 @EnableAspectJAutoProxy 注解。
3、當你需要使用CGLIB來實現AOP的時候,需要配置spring.aop.proxy-target-class=true,這個默認值是false,不然默認使用的是標準Java的實現。
其實aspectj的攔截器會被解析成AOP中的advice,最終被適配成MethodInterceptor,這些都是Spring自動完成的,如果你有興趣,詳細的過程請參考springAOP的實現。
關于集中攔截方法的區別總結:
HandlerInterceptoer攔截的是請求地址,所以針對請求地址做一些驗證、預處理等操作比較合適。當你需要統計請求的響應時間時MethodInterceptor將不太容易做到,因為它可能跨越很多方法或者只涉及到已經定義好的方法中一部分代碼。
MethodInterceptor利用的是AOP的實現機制,在本文中只說明了使用方式,關于原理和機制方面介紹的比較少,因為要說清楚這些需要講出AOP的相當一部分內容。在對一些普通的方法上的攔截HandlerInterceptoer就無能為力了,這時候只能利用AOP的MethodInterceptor。
Filter是Servlet規范規定的,不屬于spring框架,也是用于請求的攔截。但是它適合更粗粒度的攔截,在請求前后做一些編解碼處理、日志記錄等。
以上就是如何正確的使用SpringBoot AOP 攔截器,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。