编程语言
首页 > 编程语言> > SpringAOP基于注解编程中通知方法参数问题

SpringAOP基于注解编程中通知方法参数问题

作者:互联网

SpringAOP基于注解编程中通知方法参数问题

1、问题引入

在测试基于注解编程过程中,出现如下异常:

org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'calculatorImpl' defined in file [D:\Java\SSM\ssm-my\SSM\spring-aop\spring-aop\target\classes\com\hsbc\aop\CalculatorImpl.class]: Initialization of bean failed; nested exception is java.lang.IllegalArgumentException: error at ::0 formal unbound in pointcut 

2、代码介绍

Java源代码:

    // 返回通知,指明目标方法的返回值 "returning"
    @AfterReturning(value = "pointcut()", returning = "result")
    public void afterReturnAdviceMethod(Object result, JointPoint joinPoint) {
        System.out.println("------------------Return Advice--------------------");
        System.out.println("目标方法返回值结果" + result);
        System.out.println("------------------Return Advice--------------------");
        System.out.println();
        System.out.println();
    }

3、问题分析

异常说明是Bean初始化异常,应该是在构建动态代理对象的过程中出现的错误。

这里的JoinPoint并没有导错包

4、问题解决

在一顿倒腾之后发现是afterReturnAdviceMethod方法参数的问题,必须要让JoinPoint处于第一个参数的问题才不会出现异常。
改善之后的代码:

    // 返回通知,指明目标方法的返回值 "returning"
    @AfterReturning(value = "pointcut()", returning = "result")
    public void afterReturnAdviceMethod(JointPoint joinPoint, Object result) {
        System.out.println("------------------Return Advice--------------------");
        System.out.println("目标方法返回值结果" + result);
        System.out.println("------------------Return Advice--------------------");
        System.out.println();
        System.out.println();
    }

5、总结

  1. 确保JoinPoint是第一个参数可以避免该问题。
  2. 经验证AfterThrowing的方法签名也有这种情况,其他尚未验证。

如有问题,积极讨论

标签:returning,Advice,编程,System,println,result,SpringAOP,注解,out
来源: https://www.cnblogs.com/hsbc/p/16696222.html