SpringBoot使用AOP
本文介紹SpringBoot中使用Spring AOP。
簡介
AOP簡介
AOP可能對於廣大開發者耳熟能詳,它是Aspect Oriented Programming的縮寫,翻譯成中文就是:面向切面程式設計。這個可能是面試中經常提到的問題,同時它也是Spring框架中一個重大的特性,AOP主要實現的目的是針對業務處理過程中的切面進行提取,它所面對的是處理過程中的某個步驟或階段,以獲得邏輯過程中各部分之間低耦合性的隔離效果,對於我們開發中最常見的可能就是日誌記錄,事務處理,異常處理等等。
SpringBoot中使用AOP
接下來介紹SpringBoot專案中如何運用AOP。
新建專案
新建一個SpringBoot專案,在pom檔案中加入AOP依賴,完整程式碼如下:
4.0.0 com.dalaoyang springboot_aop 0.0.1-SNAPSHOT jar springboot_aop springboot_aop org.springframework.boot spring-boot-starter-parent 2.0.4.RELEASE <!-- lookup parent from repository -->UTF-8 UTF-8 1.8 org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-starter-aop org.springframework.boot spring-boot-devtools runtime org.springframework.boot spring-boot-starter-test test org.springframework.boot spring-boot-maven-plugin
建立切面
一 直接使用切面
新建一個日誌切面類,假設我們需要一個類來列印進入方法或方法執行後需要列印的日誌。
新建一個切面類
新建類LogAspect,完整程式碼如下:
package com.dalaoyang.aspect;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.ProceedingJoinPoint;
import org.springframework.stereotype.Component;
import org.aspectj.lang.annotation.*;
@Aspect
@Component
public class LogAspect {
@Pointcut("execution(public * com.dalaoyang.controller.*.*(..))")
public void LogAspect(){}
@Before("LogAspect()")
public void doBefore(JoinPoint joinPoint){
System.out.println("doBefore");
}
@After("LogAspect()")
public void doAfter(JoinPoint joinPoint){
System.out.println("doAfter");
}
@AfterReturning("LogAspect()")
public void doAfterReturning(JoinPoint joinPoint){
System.out.println("doAfterReturning");
}
@AfterThrowing("LogAspect()")
public void deAfterThrowing(JoinPoint joinPoint){
System.out.println("deAfterThrowing");
}
@Around("LogAspect()")
public Object deAround(ProceedingJoinPoint joinPoint) throws Throwable{
System.out.println("deAround");
return joinPoint.proceed();
}
}
其中:
- @Aspect 表明是一個切面類
- @Component 將當前類注入到Spring容器內
- @Pointcut 切入點,其中execution用於使用切面的連線點。使用方法:execution(方法修飾符(可選) 返回型別 方法名 引數 異常模式(可選)) ,可以使用萬用字元匹配字元,*可以匹配任意字元。
- @Before 在方法前執行
- @After 在方法後執行
- @AfterReturning 在方法執行後返回一個結果後執行
- @AfterThrowing 在方法執行過程中丟擲異常的時候執行
- @Around 環繞通知,就是可以在執行前後都使用,這個方法引數必須為ProceedingJoinPoint,proceed()方法就是被切面的方法,上面四個方法可以使用JoinPoint,JoinPoint包含了類名,被切面的方法名,引數等資訊。
二 利用自定義註解使用AOP
新建自定義註解
新建自定義註解,新建註解與新建介面類似,將interface改為@interface即可。
package com.dalaoyang.annotation;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
public @interface DoneTime {
String param() default "";
}
建立自定義註解對應切面
建立自定義註解對應切面,與上一中情況的切面類似,這裡就不在贅述了,程式碼如下:
package com.dalaoyang.aspect;
import com.dalaoyang.annotation.DoneTime;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.stereotype.Component;
import java.util.Date;
@Aspect
@Component
public class DoneTimeAspect {
@Around("@annotation(doneTime)")
public Object around(ProceedingJoinPoint joinPoint, DoneTime doneTime) throws Throwable {
System.out.println("方法開始時間是:"+new Date());
Object o = joinPoint.proceed();
System.out.println("方法結束時間是:"+new Date()) ;
return o;
}
}
建立Controller測試
建立一個IndexController進行測試,其實就是兩個普通的Web請求方法,其中index使用了自定義註解,index2沒有使用自定義註解,完整程式碼如下:
package com.dalaoyang.controller;
import com.dalaoyang.annotation.DoneTime;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class IndexController {
@GetMapping("/index")
@DoneTime(param = "IndexController")
public String index(){
System.out.println("方法執行");
return "hello dalaoyang";
}
@GetMapping("/index2")
public String index2(){
System.out.println("方法2執行");
return "hello dalaoyang";
}
}
執行測試
在瀏覽器訪問,控制檯如下:
總結
本文只是簡單介紹一下SpringBoot使用Spring AOP,當然它可能還有其他使用方法,具體的情況需要根據我們實際情況來使用。
原始碼下載 :
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/4328/viewspace-2813908/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- SpringBoot AOP的使用Spring Boot
- SpringBoot基礎篇AOP之高階使用技能Spring Boot
- springboot中的AOPSpring Boot
- 在SpringBoot中使用AOP——通知中的引數Spring Boot
- SpringBoot:使用AOP對API請求授權驗證 - GeorgeSpring BootAPI
- SpringBoot學習之整合AOPSpring Boot
- 什麼是AOP,以及在Springboot中自定義AOPSpring Boot
- SpringBoot系列(1)——AOP-入門Spring Boot
- SpringBoot專案使用AOP及自定義註解儲存操作日誌Spring Boot
- SpringBoot切面Aop的demo簡單講解Spring Boot
- SpringBoot自定義註解、AOP列印日誌Spring Boot
- Spring系列.AOP使用Spring
- SpringBoot中搭配AOP實現自定義註解Spring Boot
- springboot + aop + Lua分散式限流的最佳實踐Spring Boot分散式
- Spring AOP快速使用教程Spring
- 使用 libffi 實現 AOP
- SpringBoot部落格開發之AOP日誌處理Spring Boot
- SpringBoot(一) 如何實現AOP的許可權控制Spring Boot
- Springboot+Aop註解的方式實現分散式鎖Spring Boot分散式
- Springboot AOP 自定義註解實現系統日誌Spring Boot
- Spring(4)-AOP使用細節Spring
- 基於SpringBoot 、AOP與自定義註解轉義字典值Spring Boot
- springboot+aop切點記錄請求和響應資訊Spring Boot
- 使用MEF與Castle實現AOPAST
- 在Spring Boot框架中使用AOPSpring Boot框架
- SpringBoot之:SpringBoot中使用HATEOASSpring Boot
- SpringBoot使用RedisSpring BootRedis
- springboot 使用 rocketMQSpring BootMQ
- SpringBoot使用WebSocketSpring BootWeb
- SpringBoot使用JdbcTemplateSpring BootJDBC
- SpringBoot使用LomBokSpring BootLombok
- SpringBoot使用JPASpring Boot
- SpringBoot使用WebJarsSpring BootWebJAR
- 4、Spring+AOP介紹與使用Spring
- 【Java分享客棧】超簡潔SpringBoot使用AOP統一日誌管理-純乾貨幹到便祕JavaSpring Boot
- Spring基礎使用(三)-------XML定義AOP的使用SpringXML
- 基於SpringBoot AOP面向切面程式設計實現Redis分散式鎖Spring Boot程式設計Redis分散式
- Spring Boot使用AOP的正確姿勢Spring Boot