can't find referenced pointcut(转http://jasonhan-sh-hotmail-com.iteye.com/blog/1486737)

Coordinator
May 30, 2012 at 11:31 AM

    在使用注解配置Spring AOP过程中发现两个error:

1. error at ::0 can't find referenced pointcut

2. error at ::0 formal unbound in point

 

    对于第1个错误,网上的说法是,如果使用的spring 2.0的版本中的的aspectjrt.jar和jdk6不兼容。

    说下我的环境,JDK7 + Spring 3.6.6,因此不是aspectjrt.jar问题(何以如此确定?请看下文)。最初我也尝试使用不同版本的aspectjrt.jar文件,但都不起作用。于是我怀疑可能是aspectjweaver.jar的问题,因为使用的版本较低(1.5的)。

    于是下载了新版本aspectjweaver-1.6.12替换掉旧的,第1个错误就解决了,而且classpath中没包含aspectjrt.jar。

 

    再来说下第2个错误,贴下我的代码:

Java代码 复制代码 收藏代码
  1. @After("testBeanExecution()")   
  2. public void afterCall(Joinpoint jp) {   
  3.     System.out.println("After");   
  4. }  
	@After("testBeanExecution()")
	public void afterCall(Joinpoint jp) {
		System.out.println("After");
	}

   修改为:

Java代码 复制代码 收藏代码
  1. @After("testBeanExecution()")   
  2. public void afterCall() {   
  3.     System.out.println("After");   
  4. }  
	@After("testBeanExecution()")
	public void afterCall() {
		System.out.println("After");
	}

   这样第2个错误就没了。也就是说去掉afterCall方法中的参数就可以了。

 

   事实上这种解决办法是不对的,原因是Spring的AOP没那么残废,而是我们使用的不对。

 (1)如果要访问JoinPoint,那么我们只需要将org.aspectj.lang.JoinPoint作为通知(advice,如afterCall)中的第一个参数就可以了。那么为什么上面的代码会出错呢。很简单,请仔细看其中的参数,我使用的是org.aopalliance.intercept.Joinpoint,来自aopalliance.jar包。这是使用IDE的自动补全功能时很容易犯的一个错误。所以请确认你写的是否是JoinPoint。

  (2)如果要给通知(advice)传递参数,请使用args参数,如下:

Java代码 复制代码 收藏代码
  1. @Before("com.xyz.myapp.SystemArchitecture.dataAccessOperation() &&" +    
  2.         "args(account,..)")   
  3. public void validateAccount(Account account) {   
  4.   // ...   
  5. }