我只是在用 Spring (2.5) 玩 AspectJ (1.6),但它似乎没有以正确的方式工作。我使用以下方法设置了我的“beans.xml”:
<aop:aspectj-autoproxy/>
<bean id="testBean1" class="apackage.MyClass">
<bean id="aopBean1" class="apackage.AfterReturningExample"/>
设置了正确的命名空间和其他一些不重要的 bean。我使用一个简单的 bean 来测试建议:
package apackage;
@Aspect
public class MyClass {
public MyClass()
{
}
public Boolean testAspectJ()
{
System.out.println("returning from MyClass.testAspectJ()");
return false;
}
}
这是 aop bean:
package apackage;
@Aspect
public class AfterReturningExample {
public AfterReturningExample(){}
@AfterReturning("execution(* apackage.MyClass.*(..))")
public void test() throws Exception{
System.err.println("\n\n#### After Returning MyClass.testAspectJ()\n\n");
}
}
最后这是测试代码(在 main 方法中):
ApplicationContext ctx = new ClassPathXmlApplicationContext("apackage/beans.xml");
MyClass bean = (MyClass) ctx.getBean("testBean1");
bean.testAspectJ();
输出仅打印:
returning from MyClass.testAspectJ()
奇怪的是,如果我使用切入点:
"execution(public * *(..))"
日志显示了 AfterReturningExample 类的 System.out.println。我错过了什么?