Java 返回后AOP弹簧未按预期工作
我正在学习AOP spring并尝试一些示例。关于@AfterReturning,我所了解的是,只有当目标成功返回并且与切入点匹配时,才会调用该方法。然而,在我的例子中,如下图所示,我有一个切入点,它定义了只返回字符串的所有方法,但它调用了所有void方法以及返回字符串的方法 我的忠告是:Java 返回后AOP弹簧未按预期工作,java,spring,aop,spring-aop,Java,Spring,Aop,Spring Aop,我正在学习AOP spring并尝试一些示例。关于@AfterReturning,我所了解的是,只有当目标成功返回并且与切入点匹配时,才会调用该方法。然而,在我的例子中,如下图所示,我有一个切入点,它定义了只返回字符串的所有方法,但它调用了所有void方法以及返回字符串的方法 我的忠告是: @AfterReturning(value= "execution(* com.aop..CustomerServiceImpl.*(..))", returning= "string")
@AfterReturning(value= "execution(* com.aop..CustomerServiceImpl.*(..))",
returning= "string")
public void returnStringPointcut(JoinPoint joinPoint,String string){
System.out.println("logAfter() is running!");
System.out.println("String : " + string);
System.out.println("hijacked : " + joinPoint.getSignature().getName());
System.out.println("******");
}
请在下面找到我的Impl课程:
public void addCustomer() {
// TODO Auto-generated method stub
}
public String getCustomer() {
// TODO Auto-generated method stub
return "string";
}
public boolean deleteCustomer() {
// TODO Auto-generated method stub
return false;
}
public void addCustomerAppended() {
// TODO Auto-generated method stub
}
public void deleteCustomerVoid() {
// TODO Auto-generated method stub
//return false;
}
请在下面找到我的MainApp类:
public class App {
public static void main(String[] args)
{
ApplicationContext context = new ClassPathXmlApplicationContext(
"Spring-Customer.xml");
CustomerService cs = context.getBean("customerBo", CustomerService.class);
cs.addCustomer();
cs.addCustomerAppended();
cs.deleteCustomer();
cs.deleteCustomerVoid();
cs.getCustomer();
}
}
我希望只调用getCustomer(),因为它是唯一返回字符串的,但在运行应用程序时,我在控制台中得到以下输出:
logAfter() is running!
String : null
hijacked : addCustomer
******
logAfter() is running!
String : null
hijacked : addCustomerAppended
******
logAfter() is running!
String : null
hijacked : deleteCustomerVoid
******
logAfter() is running!
String : string
hijacked : getCustomer
******
请在下面找到我的pom.xml:
<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>com.aop.spring</groupId>
<artifactId>SpringAopOnly</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>SpringAopOnly</name>
<url>http://maven.apache.org</url>
<properties>
<spring.version>3.0.5.RELEASE</spring.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.8.2</version>
<scope>test</scope>
</dependency>
<!-- Spring 3 dependencies -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<!-- Spring AOP -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aop</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjrt</artifactId>
<version>1.6.11</version>
</dependency>
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
<version>1.6.11</version>
</dependency>
</dependencies>
</project>
4.0.0
com.aop.spring
春天
0.0.1-快照
罐子
春天
http://maven.apache.org
3.0.5.1发布
UTF-8
朱尼特
朱尼特
4.8.2
测试
org.springframework
弹簧芯
${spring.version}
org.springframework
spring上下文
${spring.version}
org.springframework
春季aop
${spring.version}
org.aspectj
aspectjrt
1.6.11
org.aspectj
aspectjweaver
1.6.11
请在下面找到我的配置文件:
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.0.xsd ">
<!-- <aop:aspectj-autoproxy /> -->
<aop:aspectj-autoproxy>
<aop:include name ="logAspect" />
</aop:aspectj-autoproxy>
<bean id="customerBo" class="com.aop.impl.CustomerServiceImpl" />
<!-- Aspect -->
<bean id="logAspect" class="com.aop.aspect.CustomerAspect" />
</beans>
你知道为什么它会调用void方法吗
我还尝试将afterReturning从String改为boolean,然后得到预期的结果,即只调用deleteCustomer,因为它返回一个boolean
非常感谢您的回复。返回的
参数只指定
通知签名中用于绑定返回文件的参数的名称
重视
你真正的切入点
@AfterReturning(value= "execution(* com.aop..CustomerServiceImpl.*(..))",
returning= "string")
正在指定
execution(* com.aop..CustomerServiceImpl.*(..))
其中*
匹配所有返回类型
你应该把它改成
execution(java.lang.String com.aop..CustomerServiceImpl.*(..))
如果只希望方法声明为返回字符串
注释value
表达式中的返回类型和方法参数类型在建议的方法中都起作用。比如说
@AfterReturning(value = "execution(String com.aop..CustomerServiceImpl.*(..))", returning = "random")
public void returnStringPointcut(JoinPoint joinPoint, Integer random) {
什么都配不上
一个旁注,你应该考虑升级你的Spring和AspectJ版本。我认为这些问题中的很多要么已经解决,要么整个库更加稳定。
我无法重现您看到的内容。有什么你没给我们看的吗?您使用的是哪个版本的Spring和AspectJ?非常感谢您的回复,我已经更新了我的问题