English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
Advice Around предоставляется @Around Аннотация означает. Она выполняется до и после точки подключения. Это наиболее мощный совет. Он также предоставляет конечным пользователям больше контроля, чтобы они могли обрабатывать ProceedingJoinPoint.
Позвольте реализовать советы вокруг приложения.
步骤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>Demo project for 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>
Шаг 9: Создать имя пакета com.w3codebox.service.
Шаг 10: 在上面的包中创建一个名为 BankService класса.
В этом классе мы определяем имя метод displayBalance(). Она проверяет счет. Если счет совпадает, то возвращает общую сумму, в противном случае возвращает сообщение.
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("Метод вызова beforeAdvice() метод" + jp.getSignature().getName() + " method"); try {}} jp.proceed(); } finally {}} } System.out.println("Метод вызова afterAdvice() метод" + jp.getSignature().getName() + " method"); } }
Шаг 13: Открыть AopAroundAdviceExampleApplication.java файл и добавьте аннотацию @EnableAspectJAutoProxy
Эта аннотация активирует поддержку обработки компонентов с AspectJ. @Aspect компоненты с аннотацией. Он используется вместе с аннотацией @Configuration.
ConfigurableApplicationContext Это интерфейс, который предоставляет не только методы клиента контекста приложения ApplicationContext, но и инструменты для конфигурации контекста приложения.
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.close(); } }
После создания всех пакетов и классов структура каталога проекта будет выглядеть следующим образом:
Теперь, запустите приложение.
Шаг 14: Открыть AopAroundAdviceExampleApplication.java и запустите Java приложение.
В上面的 выводе我们看到 метод aroundAdvice() вызывается дважды. Сначала, в процессе выполнения displayBalance()Метод до, затем, в процессе выполнения displayBalance()Метод после. Называется консультацией.