Spring boot教程-Spring Boot AOP返回后建议
Spring Boot AOP返回后建议
返回后建议是Spring AOP中的一种建议,它在连接点的执行完成后(正常执行)后调用。如果抛出异常,则不会调用该建议。我们可以使用@AfterReturning注解来实现返回后的建议。该注解将一个函数标记为在PointCut覆盖的方法之前执行的建议。
返回后建议在匹配的方法执行返回一个值时运行。在returning属性中定义的名称必须与建议方法中参数的名称相对应。当方法返回一个值时,该值将作为相应的参数值传递给建议方法。
让我们在应用程序中实现返回后的建议。
Spring Boot返回后建议示例 步骤1:打开Spring Initializr http://start.spring.io。
步骤2:提供Group名称。我们提供了Group名称cn.javatiku。
步骤3:提供Artifact Id。我们提供了Artifact Id aop-after-returning-advice-example。
步骤4:添加Spring Web依赖项。
步骤5:单击“Generate”按钮。当单击“Generate”按钮时,它将所有规格封装在一个jar文件中,并下载到本地系统中。
步骤6:提取下载的jar文件。
步骤7:使用以下步骤导入文件夹:
File -> Import -> Existing Maven Projects -> Next -> 浏览文件夹aop-after-returning-advice-example -> Finish。
步骤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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>cn.javatiku</groupId>
<artifactId>aop-after-returning-advice-example</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>aop-after-returning-advice-example</name>
<description>Demo project for Spring Boot</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.2.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
</properties>
<dependencies>
<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>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
步骤9:在src/main/java文件夹中创建一个名为cn.javatiku.model的包。
步骤10:在包cn.javatiku.model中创建一个名为Account的类。
在Account类中,执行以下操作:
- 定义了两个类型为String的变量accountNumber和accountType。
- 右键单击文件->Source->Generate Constructor using Fields
- 生成Getter方法。
- 右键单击文件->Source->Generate Getters and Setters -> 选择Getters -> Generate
- 生成一个toString()方法。
- 右键单击文件->Source->Generate toString()...
Account.java
package cn.javatiku.model;
public class Account
{
private String accountNumber;
private String accountType;
public Account(String accountNumber, String accountType)
{
super();
this.accountNumber = accountNumber;
this.accountType = accountType;
}
public String getAccountType()
{
return accountType;
}
public String getAccountNumber()
{
return accountNumber;
}
@Override
public String toString()
{
return "Account [accountNumber=" + accountNumber+ ", accountType=" + accountType + "]";
}
}
步骤11:在包cn.javatiku.service.impl中创建另一个名为AccountServiceImpl的类。
在这个类中,我们定义了一个账户服务。
AccountServiceImpl.java
package cn.javatiku.service.impl;
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
import org.springframework.stereotype.Service;
import cn.javatiku.model.Account;
@Service
public class AccountServiceImpl implements AccountService
{
//storing account detail in the HashMap
private static Map<String,Account> map = null;
static
{
map = new HashMap<>();
//adding account detail in the map
map.put("M4546779", new Account("10441117000", "Saving Account"));
map.put("K2434567", new Account("10863554577", "Current Account"));
}
@Override
public Account getAccountByCustomerId(String customerId) throws Exception
{
if(customerId ==null)
{
throw new Exception("Invalid! Customer Id");
}
Account account= null;
Set<Entry<String, Account>> entrySet = map.entrySet();
for (Entry<String, Account> entry : entrySet)
{
if(entry.getKey().equals(customerId))
{
account= entry.getValue();
}
}
return account;
}
}
步骤12:在包cn.javatiku.service.impl中创建一个名为AccountService的接口。
AccountService.java
package cn.javatiku.service.impl;
import cn.javatiku.model.Account;
//creating interface that throws exception if the customer id not found
public interface AccountService
{
public abstract Account getAccountByCustomerId(String customerId)
throws Exception;
}
步骤13:在包cn.javatiku.aspect中创建一个名为AccountAspect的类。
在这个类中,我们使用@AfterReturning注解实现了返回后的建议。我们还定义了一个方法afterReturningAdvice()。
注意:在返回属性中定义的名称(account)必须与建议方法中参数的名称相对应。
AccountAspect.java
package cn.javatiku.aspect;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.AfterReturning;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.stereotype.Component;
import cn.javatiku.model.Account;
@Aspect
@Component
public class AccountAspect
{
//implementing after returning advice
@AfterReturning(value="execution(* cn.javatiku.service.impl.AccountServiceImpl.*(..))",returning="account")
public void afterReturningAdvice(JoinPoint joinPoint, Account account)
{
System.out.println("After Returing method:"+joinPoint.getSignature());
System.out.println(account);
}
}
步骤14:打开AopAfterReturningAdviceExampleApplication.java文件,并添加注解@EnableAspectJAutoProxy。
该注解启用对标记有@Aspect注解的组件的支持。它与xml配置中的tag类似。
我们使用了注解@EnableAspectJAutoProxy的proxyTargetClass属性。属性proxyTargetClass=true允许我们使用CGLIB(Code Generation Library)代理,而不是默认的基于接口的JDK代理方法。
AopAfterReturningAdviceExampleApplication.java
package cn.javatiku;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.ConfigurableApplicationContext;
import org.springframework.context.annotation.EnableAspectJAutoProxy;
import cn.javatiku.model.Account;
import cn.javatiku.service.impl.AccountService;
import cn.javatiku.service.impl.AccountServiceImpl;
@SpringBootApplication
//@EnableAspectJAutoProxy annotation enables support for handling the components marked with @Aspect annotation. It is similar to tag in the xml configuration.
@EnableAspectJAutoProxy(proxyTargetClass=true)
public class AopAfterReturningAdviceExampleApplication
{
public static void main(String[] args)
{
ConfigurableApplicationContext ac = SpringApplication.run(AopAfterReturningAdviceExampleApplication.class, args);
//Fetching the account object from the application context
AccountService accountService = ac.getBean("accountServiceImpl", AccountServiceImpl.class);
Account account;
try
{
account = accountService.getAccountByCustomerId("K2434567");
if(account != null)
System.out.println(account.getAccountNumber()+"\t"+account.getAccountType());
}
catch (Exception e)
{
System.out.println(e.getMessage());
}
}
}
创建所有的类和包后,项目目录如下:
步骤17:打开AopAfterReturningAdviceExampleApplication.java文件并将其作为Java应用程序运行。它显示的输出如下:
在下一节中,我们将了解after throwing advice。