English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

SpringBoot AOP @Around

Il consiglio attorno è fornito da @Around L'annotazione rappresenta. Esegue prima e dopo il punto di connessione. Questo è il suggerimento più potente. Fornisce anche più controllo agli utenti finali, permettendo loro di gestire ProceedingJoinPoint.

Implementiamo suggerimenti attorno all'applicazione.

Esempio di Spring Boot @Around

步骤1: 打开Spring Initializr http://start.spring.io 。

步骤2: 提供 名称。我们提供了组名 com.w3codebox。

步骤3: 提供了 Artifact Id。提供Artifact Id aop-around-advice-example。

步骤4: 添加 Spring Web 依赖项。

步骤5: 点击 生成按钮。当我们单击"生成"按钮时,它将所有规范包装在 jar 文件中,并将其下载到本地系统。

第6步: 提取下载的jar文件。

步骤7: 使用以下步骤导入文件夹:

文件->导入->现有Maven项目->下一步->浏览文件夹 aop-around-advice-example ->完成。

步骤8: 打開 pom.xml 文件并添加以下 AOP 依赖项。它是使用 Spring AOP AspectJ 开始面向方面编程。

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

pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.2.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.w3codebox</groupId>
<artifactId>aop-around-advice-example</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>aop-around-advice-example</name>
<description>Progetto demo per Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
<exclusions>
<exclusion>
<groupId>org.junit.vintage</groupId>
<artifactId>junit-vintage-engine</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>

Passaggio 9: Crea un nome pacchetto com.w3codebox.service.

Passaggio 10: 在上面的包中创建一个名为 BankService di classe.

In questa classe, abbiamo definito un nome metodo displayBalance(). Controlla l'account. Se l'account corrisponde, restituisce l'importo totale, altrimenti restituisce un messaggio.

BankService.java

package com.w3codebox.service;
import org.springframework.stereotype.Service;
@Service
public class BankService 
{}
public void displayBalance(String accNum) 
{}
System.out.println("Inside displayBalance() method");
if(accNum.equals("12345")) 
{}
System.out.println("Total balance: 10,000");
}
else 
{}
System.out.println("Sorry! wrong account number.");
}
}
}

步骤11: 创建另一个名为 com.w3codebox.aspect的包。

步骤12: 在上面的包中创建一个名为 BankAspect的类。

在下面的类中,我们定义了两个名为 logDisplayingBalance() aroundAdvice()方法的方法。

BankAspect.java

package com.w3codebox.aspect;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.stereotype.Component;
//在应用程序中启用spring AOP功能
@Aspect
@Component
public class BankAspect
{}
    //显示所有可用的方法,即将为所有方法调用通知
    @Pointcut(value= "execution(* com.w3codebox.service.BankService.*(..))")
    private void logDisplayingBalance() 
    {} 
    }
    //声明在方法与切入点表达式匹配之前和之后应用的 around 通知
    @Around(value= "logDisplayingBalance()")
    public void aroundAdvice(ProceedingJoinPoint jp) throws Throwable 
    {}
        System.out.println("Metodo chiamato prima dell'aroundAdvice()" + jp.getSignature().getName() + " method");
        try 
        {}
            jp.proceed();
        } 
        finally 
        {}
        }
        System.out.println("Metodo chiamato afterAdvice()" + jp.getSignature().getName() + " method");
    }
}

Passaggio 13: 打開 AopAroundAdviceExampleApplication.java File e aggiungi annotazioni @EnableAspectJAutoProxy。

Questa annotazione abilita il supporto per il trattamento dei componenti etichettati con AspectJ @Aspect Componenti annotati. Viene utilizzato insieme all'annotazione @Configuration.

ConfigurableApplicationContext È un'interfaccia, oltre ai metodi client del contesto dell'applicazione di ApplicationContext, fornisce strumenti per configurare il contesto dell'applicazione.

AopAroundAdviceExampleApplication.java

package com.w3codebox;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.ConfigurableApplicationContext;
import org.springframework.context.annotation.EnableAspectJAutoProxy;
import com.w3codebox.service.BankService;
@SpringBootApplication
//@EnableAspectJAutoProxy 注解支持处理标记为 @Aspect annotation 的组件。它类似于 xml 配置中的标记。
@EnableAspectJAutoProxy
public class AopAroundAdviceExampleApplication 
{}
    public static void main(String[] args) 
    {}
    ConfigurableApplicationContext context = SpringApplication.run(AopAroundAdviceExampleApplication.class, args);
    //從應用程序上下文獲取employee對象。
    BankService bank = context.getBean(BankService.class);
    //顯示帳戶餘額
    String accnumber = "12345";
    bank.displayBalance(accnumber);
    //關閉context對象
    context.close();
    }
}

創建所有包和類之後,項目目錄如下所示:

現在,運行應用程序。

步驟14: 打開 AopAroundAdviceExampleApplication.java 並將其作為Java運行應用程序。

在上面的輸出中,我們看到了方法aroundAdvice()會調用兩次。首先,在執行 displayBalance()方法之前,其次,在執行 displayBalance()方法之後。稱為諮詢。