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

SpringBoot AOP @Around

Advice Around предоставляется @Around Аннотация означает. Она выполняется до и после точки подключения. Это наиболее мощный совет. Он также предоставляет конечным пользователям больше контроля, чтобы они могли обрабатывать ProceedingJoinPoint.

Позвольте реализовать советы вокруг приложения.

Пример 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>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()Метод после. Называется консультацией.