English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
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.
步骤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()方法之後。稱為諮詢。