中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SpringBoot中怎么使用面向切面編程

發布時間:2021-06-22 16:25:19 來源:億速云 閱讀:248 作者:Leah 欄目:編程語言

這期內容當中小編將會給大家帶來有關SpringBoot中怎么使用面向切面編程,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

一、什么是AOP?

AOP,面向切面編程,一句話說明,把一些公共的、和業務無關的功能性代碼抽取出來,在運行的時候動態的往業務方法上植入。利用 AOP 可以對業務邏輯的各個部分進行隔離,從而使得業務邏輯各部分之間的耦合度降低,提高程序的可重用性,同時提高了開發的效率。

二、AOP常用場景:

  1. 事務開啟關閉控制

  2. 日志記錄

  3. 權限校驗

三、AOP 相關概念介紹:

  • Joinpoint(連接點):類里面可以被增強的方法即為連接點。例如,想要修改哪個方法的功能,那么該方法就是一個鏈接點。

  • Target(目標對象):要增強的類成為 Target。

  • Pointcut(切入點):對 Jointpoint 進行攔截的定義即為切入點。例如,攔截所有以 insert 開始的方法,這個定義即為切入點。

  • Advice(通知):攔截到 Jointpoint 之后要做的事情就是通知。通知分為前置通知、后置通知、異常通知、最終通知和環繞通知。例如,前面說到的打印日志監控就是通知。

  • Aspect(切面):即 Pointcut 和 Advice 的結合。

通知方法的幾種類型:

  • 前置通知(Before advice):在某個連接點(Join point)之前執行的通知,但這個通知不能阻止連接點的執行(除非它拋出一個異常)。

  • 后置通知(After(finally)advice):當某個連接點(Join point)退出的時候執行的通知(不論是正常返回還是發生異常退出)。

  • 返回通知(After returning advice):在某個連接點(Join point)正常完成后執行的通知。例如,一個方法沒有拋出任何異常正常返回。

  • 異常通知(After throwing advice):在方法拋出異常后執行的通知。

  • 環繞通知(Around advice):包圍一個連接點(Join point)的通知,如方法調用。這是最強大的一種通知類型。環繞通知可以在方法前后完成自定義的行為。它也會選擇是否繼續執行連接點或直接返回它們自己的返回值或拋出異常來結束執行。

SpringBoot中怎么使用面向切面編程

四、安裝配置

Spring Boot 在 Spring 的基礎上對 AOP 的配置提供了自動化配置解決方案,我們只需要修改 pom.xml 文件,添加 spring-boot-starter-aop 依賴即可。

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-aop</artifactId>
</dependency>

五、編寫代碼

1、編寫controller

@RestController
public class DemoController {
 
    @Autowired
    UserService userService;
 
    @GetMapping("/demo")
    public String demo(Integer id) {
        return userService.getUserById(id);
    }
}

2、編寫service

@Service
public class UserService {

   public String getUserById(Integer id) {
       System.out.println("getUserById(" + id + ")...");
       // 等待2秒
       try {
           Thread.sleep(2000);
       }
       catch(InterruptedException e) {
           e.printStackTrace();
       }
       return "piao";
   }

}

3、編寫切面

注解說明:

(1)@Aspect 注解:表明這是一個切面類。

(2)@Pointcut 注解:表明這是一個切入點。

  • execution 中的第一個 * 表示方法返回任意值

  • 第二個 * 表示 service 包下的任意類

  • 第三個 * 表示類中的任意方法,括號中的兩個點表示方法參數任意,即這里描述的切入點為 service 包下所有類中的所有方法。

(3)@Before 注解:表示這是一個前置通知,該方法在目標方法之前執行。

  • 通過 JoinPoint 參數可以獲取目標方法的方法名、修飾符等信息。

(4)@After 注解:表示這是一個后置通知,該方法在目標執行之后執行。

(5)@AfterReturning 注解:表示這是一個返回通知,在該方法中可以獲取目標方法的返回值。

  • returning 參數是指返回值的變量名,對應方法的參數。

  • 注意:本樣例在方法參數中定義 result 的類型為 Object,表示目標方法的返回值可以是任意類型。若 result 參數的類型為 Long,則該方法只能處理目標方法返回值為 Long 的情況。

(6)@AfterThrowing 注解:表示這是一個異常通知,即當目標方法發生異常,該方法會被調用。

  • 樣例中設置的異常類型為 Exception 表示所有的異常都會進入該方法中執行。

  • 若異常類型為 ArithmeticException 則表示只有目標方法拋出的 ArithmeticException 異常才會進入該方法的處理。

(7) @Around 注解:表示這是一個環繞通知。環繞通知是所有通知里功能最為強大的通知,可以實現前置通知、后置通知、異常通知以及返回通知的功能。

  • 目標方法進入環繞通知后,通過調用 ProceedingJointPoint 對象的 proceed 方法使目標方法繼續執行,開發者可以在次修改目標方法的執行參數、返回值值,并且可以在此目標方法的異常。

@Aspect
@Component
public class LogAspect {

    // 定義一個切入點
    @Pointcut("execution(* com.example.demo.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 {
        String name = pjp.getSignature().getName();
        // 統計方法執行時間
        long start = System.currentTimeMillis();
        Object result = pjp.proceed();
        long end = System.currentTimeMillis();
        System.out.println(name + "方法執行時間為:" + (end - start) + " ms");
        return result;
    }

}

六、驗證結果

1、請求接口:http://127.0.0.1:8086/demo

SpringBoot中怎么使用面向切面編程

2、查看控制臺信息:

SpringBoot中怎么使用面向切面編程

上述就是小編為大家分享的SpringBoot中怎么使用面向切面編程了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

山西省| 双柏县| 盐池县| 米脂县| 襄垣县| 绥棱县| 葫芦岛市| 惠水县| 广南县| 华安县| 东宁县| 奈曼旗| 弋阳县| 台东县| 永善县| 常州市| 连山| 泰和县| 平塘县| 张家港市| 八宿县| 灵丘县| 东山县| 东阿县| 曲水县| 临漳县| 新建县| 宁津县| 钦州市| 田林县| 廉江市| 华池县| 伊宁市| 临澧县| 鄄城县| 松江区| 互助| 岳普湖县| 游戏| 清水县| 湄潭县|