SpringBoot整合Web之AOP配置詳解
配置AOP
AOP簡介
要介紹面向切面變成(Aspect-Oriented Programming,AOP),需要先考慮一個這樣的場景:公司有一個人力資源管理系統目前已經上線,但是系統運行不穩定,有時運行的很慢,為瞭檢測到底是哪個環節出現問題瞭,開發人員想要監控每一個方法執行的時間,再根據這些執行時間判斷出問題所在。當問題解決後,再把這些監控移除掉。系統目前已經運行,如果手動修改系統成千上萬個方法,工作量太大,而且這些監控方法以後還要移除掉;如果能夠在系統運行過程中動態添加代碼,就能很好的解決問題。這種在系統運行時動態添加代碼的方式成為面向切面編程(AOP)。Spring Boot 對 AOP 提供瞭很好的支持。在 AOP 中,有一些常見的概念需要瞭解:
- Joinpoint(連接點):類裡面可以被增強的方法即為連接點。例如,想修改那個方法的功能,那麼該方法就是一個連接點
- Pointcut(切入點):對 Joinpoint 進行攔截的定義即為切入點。例如,攔截所有以 insert 開始的方法,這個定義即為切入點
- Advice(通知):攔截到 Joinpoint 之後所要做的事情就是通知。例如,之前說到的打印日志監控。通知分為前置通知、後置通知、異常通知、最終通知、環繞通知
- Aspect(切面):Pointcut 和 Advice 的結合
- Target(目標對象):要增強的類成為 Target
Spring Boot 支持
Spring Boot 在 Spring 的基礎上對 AOP 的配置提供瞭自動化配置解決方案 spring-boot-starter-aop ,首先引入依賴,如下:
<!-- AOP 依賴 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId> </dependency>
然後在com.sang.aop.service 包下創建 UserService 類,如下:
@Service public class UserService { public String getUserById(Integer id){ System.out.println("get..."); return "user"; } public void deleteUserById(Integer id){ System.out.println("delete..."); } }
然後創建切面,如下:
@Component @Aspect public class LogAspect { @Pointcut("execution(* com.sang.aop.service.*.*(..))") public void pc1() { } @Before(value = "pc1()") public void before(JoinPoint jp) { String name = jp.getSignature().getName(); System.out.println(name + "方法開始執行..."); } @After(value = "pc1()") public void after(JoinPoint jp) { String name = jp.getSignature().getName(); System.out.println(name + "方法執行結束..."); } @AfterReturning(value = "pc1()", returning = "result") public void afterReturning(JoinPoint jp, Object result) { String name = jp.getSignature().getName(); System.out.println(name + "方法返回值為:" + result); } @AfterThrowing(value = "pc1()",throwing = "e") public void afterThrowing(JoinPoint jp, Exception e) { String name = jp.getSignature().getName(); System.out.println(name+"方法拋異常瞭,異常是:"+e.getMessage()); } @Around("pc1()") public Object around(ProceedingJoinPoint pjp) throws Throwable { return pjp.proceed(); } }
代碼解釋:
- @Aspect 註解表明這是一個切面類
- pc1() 方法使用瞭 @Pointcut() 註解 ,這是一個切入點定義。execution 中的第一個 * 表示方法返回任意值,第二個 * 表示 service 包下的任意類,第三個 * 表示類中的任意方法,括號中的兩個點表示方法參數任意,即這裡描述的切入點為 service 包下所有類中的所有方法
- before() 方法使用瞭 @Before註解 ,表示這是一個前置通知,該方法在目標方法執行之前執行。通過 JoinPoint 參數可以獲取目標方法的方法名、修飾符等信息
- after() 方法使用瞭 @After註解,表示這是一個後置通知,該方法在目標方法執行之後執行
- afterReturning() 方法使用瞭 @AfterReturning 註解,表示這是一個返回通知,在該方法中可以獲取目標方法的返回值。@AfterReturning 註解的 returning 參數是指返回值的變量名,對應方法的參數。註意,在方法參數中定義瞭 result 的類型為 Object ,表示目標方法的返回值可以使任意類型,若 result 參數的類型為 Long ,則該方法隻能處理目標方法返回值為 Long 的情況
- afterThrowing() 方法使用瞭 @AfterThrowing 註解,表示這是一個異常通知,即當目標方法發生異常時,該方法會被調用,異常類型為 Exception 表示所有的異常都會進入該方法中執行,若異常類型為 ArithmeticException ,則表示隻有目標方法拋出 ArithmeticException 異常時才會進入該方法處理
- around() 方法使用瞭 @Around 註解,表示這是一個環繞通知。環繞通知是所有通知裡功能最為強大的通知,可以實現前置通知、後置通知、異常通知以及返回通知的功能。目標方法進入環繞通知後,通過調用 ProceedingJoinPoint 對象的 proceed 方法使目標方法繼續執行,開發者可以在此修改目標方法的執行參數、返回值等,並且可以在此處理目標方法的異常
配置完成後,接下來在Controller 中創建接口,分別調用 Userservice 中的兩個方法,即可看到 LogAspect 中的代碼動態的嵌入目標方法中執行瞭,如下:
getUserById方法開始執行…
get…
getUserById方法返回值為:user
getUserById方法執行結束…
deleteUserById方法開始執行…
delete…
deleteUserById方法返回值為:null
deleteUserById方法執行結束…
其它
自定義歡迎頁
Spring Boot 項目在啟動後,首先會去靜態資源路徑下查找 index.html 作為首頁文件,若查找不到,則會去查找動態的 index.html 作為首頁文件。
例如,如果想使用靜態的 index.html 頁面作為項目的首頁,隻需在 resources/static 目錄下創建 index.html 文件疾苦。若想使用動態頁面作為項目首頁,則需在 resources/templages 目錄下創建 index.html (使用Thymeleaf 模板) 或者 index.ftl(使用 FreeMarker 模板),然後在 Controller 中返回邏輯視圖名,如下:
@Controller public class IndexController { @RequestMapping("/index") public String index(){ return "index"; } }
運行項目,輸入"http://localhost:8081",查看結果
自定義 favicon
favicon.ico 是瀏覽器選項卡左上角的圖標,可以放在靜態資源路徑下或者類路徑下,靜態資源路徑下的 favicon.ico 優先級高於類路徑下的 favicon.ico
可以使用在線轉換網站:https://www.bitbug.net/ 將一張普通圖片轉為 .ico 圖片,轉換成功後,將文件重命名為 favicon.ico ,然後復制到 resources/static 目錄下,如圖
啟動項目,查看效果
註意:清緩存,然後 Ctrl+F5 強制刷新
除去某個自動配置
Spring Boot 中提供瞭大量的自動化配置類,在 Spring Boot 的入口類上有一個 @SpringBootApplication 註解。該註解是一個組合註解,由 @SpringBootConfiguration、@EnableAutoConfiguration、@ComponentScan 組成,其中 @EnableAutoConfiguration 註解開啟自動化配置,相關的自動化配置就會被使用。如果開發者不想使用某個自動化配置,按如下方式除去相關配置即可:
@SpringBootApplication @EnableAutoConfiguration(exclude = {ErrorMvcAutoConfiguration.class}) public class Chapter04Application { public static void main(String[] args) { SpringApplication.run(Chapter04Application.class, args); } }
在 @EnableAutoConfiguration 註解中使用 exclude 屬性去除 Error 的自動化配置類,這時如果在 resources/static/error 目錄下創建 4xx.htnl、5xx.html ,訪問出錯時就不會自動跳轉瞭。由於 @EnableAutoConfiguration 註解的 exclude 屬性值是一個數組,因此有多個要排除的自動化配置文件隻需要繼續添加即可。除瞭這種配置方式外,也可在 application.properties 中配置,如下:
spring.autoconfigure.exclude=org.springframework.boot.autoconfigure.web.servlet.error.ErrorMvcAutoConfiguration
添加前
添加後
到此這篇關於SpringBoot整合Web之AOP配置詳解的文章就介紹到這瞭,更多相關SpringBoot AOP配置內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- 基於springboot實現一個簡單的aop實例
- Springboot如何使用Aspectj實現AOP面向切面編程
- SpringAOP切入點規范及獲取方法參數的實現
- SpringBoot開發教程之AOP日志處理
- 基於SpringAop中JoinPoint對象的使用說明