背景
项目需求,需要检测其他同事的部分功能,自然想到的切面编程,按照网上的流程,很容易就完成了AOP的触发,但最近突然发现,之前的一个AOP突然就失效了
切面代码
@AfterReturning(pointcut = "save()", returning = "result")
publicvoid afterApiChange(JoinPoint joinPoint, SwaggerResultUtil<String> result) {
// 业务代码
}
切点代码
public SwaggerResultUtil<Object> save() {
// 业务代码
}
原因分析
这里和网上说的乱七八糟的都没关系,是因为最初返回值的泛型是String,后来那个同事业务需求,返回值泛型变成了Object,导致AOP匹配不上
解决方法
将泛型去掉
@AfterReturning(pointcut = "save()", returning = "result")
publicvoid afterApiChange(JoinPoint joinPoint, SwaggerResultUtil result) {
// 业务代码
}
解决思路(后记)
之所以能发现,是因为考虑到之前是OK的,突然不行,自己切面代码又没变化,出问题的点大概率是对方,然后看对方的提交记录,重点看最近的差异点,一点点还原测试,最终找到这个坑。