天天看点

Spring AOP异常处理(error at ::0 formal unbound in pointcut)

【问题背景】

基于XML配置开发AspectJ和基于注解开发AspectJ时报错:error at ::0 formal unbound in pointcut

【问题分析】

切点绑定失败,必然是AspectJ相关配置出现问题。

【问题解决】

逐一查看配置,包括每个切点的定义,切面配置,通知配置。经排查,发现是“异常通知”配置有误,没有将异常throwing出去。

修改前:

<aop:after-throwing method="exceptAdvice" pointcut-ref="pointCut1"/>

@AfterThrowing(value="pointCut1()")

       public void exceptAdvice(Throwable e) {

              System.out.println("异常通知,程序执行异常"+e.getMessage());

 }

 修改后:

<aop:after-throwing method="exceptAdvice" pointcut-ref="pointCut1" throwing="e"/>

@AfterThrowing(value="pointCut1()",throwing="e")

       public void exceptAdvice(Throwable e) {

              System.out.println("异常通知,程序执行异常"+e.getMessage());

}

 【总结】

Spring AOP出现问题很容易排查的,常见的报错原因可能有:

1.缺少依赖包

2.包扫描失败或未正确扫描目标类或切面类所在的包

3.注解配置时,(函数本身或注解)参数遗漏或者参数错误、缺少注解等。

4.配置文件中配置AspectJ时,标签属性遗漏或属性值格式不正确。

继续阅读