Spring AOP对嵌套方法不起作用的解决

网友投稿 278 2022-09-05


Spring AOP对嵌套方法不起作用的解决

目录Spring AOP对嵌套方法不起作用要解决这个问题Spring AOP、嵌套调用失效及解决加入注解获取当前代理的接口需要嵌套调用的Service实现它调用的时候改写代码

Spring AOP对嵌套方法不起作用

今天在调研系统操作记录日志时,好多教程都是借助于Spring AOP机制来实现。于是也采用这种方法来实现。在Service中的删除日志方法上注解自定义的切点,但是执行没有生效。

代码如下:

//尝试删除溢出日志

public synchronized void tryDelOverflowLog() {

logNum++;

if (logNum - LogConst.MAX_NUM > 0) {

int delNum = logNum - LogConst.MAX_NUM + LogConst.EXTRA_NUM;

logNum -= delNum;

removeOverflowLog(delNum);

}

}

//日志溢出后,删除最新入库的日志

@ServiceLog(type = LogConst.TYPE_LOG_RECORD, description = "操作日志缓存区溢出,系统自动清空缓存区")

public void removeOverflowLog(int delNum) {

custLogMapper.removeOverflowLog(delNum);

}

在使用 Spring AOP 的时候,我们从 IOC 容器中获取的 Service Bean 对象其实都是代理对象,而不是那些 Service Bean 对象本身,也就是说获取的并不是被代理对象或代理目标。当我在自己的 Service 类中使用 this 关键字嵌套调用同类中的其他方法时,由于 this 关键字引用的并不是该 Service Bean 对象的代理对象,而是其本身,故 Spring AOP 是不能拦截到这些被嵌套调用的方法的。

要解决这个问题

最简单的方法是把自身注入到自身,用注入的这个自身去调用本方法。或者你也可以不用spring aop而是用aspectj weUotcZyaving,倒是可以测底的解决该问题。我采用的是把自身注入到自身中。

/**

* 通过注入自身解决,Spring AOP嵌套调用不生效的问题

*/

@Autowired

private ApplicationContext applicationContext;

private LogService self;

@PostConstruct

private void init() {

self = (LogService) applicationContext.getBean("logService");

}

//尝试删除溢出日志

public synchronized void tryDelOverflowLog() {

logNum++;

if (logNum - LogConst.MAX_NUM > 0) {

int delNum = logNum - LogConst.MAX_NUM + LogConst.EXTRA_NUM;

logNum -= delNum;

self.removeOverflowLog(delNum);

}

}

Spring AOP、嵌套调用失效及解决

加入注解

UotcZy

@EnableAspectJAutoProxy(proxyTargetClass = true, exposeProxy = true)

获取当前代理的接口

public interface ICurrentAopProxyService {

default T getCurrentProxyService() {

return (T) AopContext.currentProxy();

}

}

需要嵌套调用的Service实现它

调用的时候改写代码

public SysMerchantVersion selectByMerchantId(Long merchantId) {

return getCurrentProxyService().getOne(new QueryWrapper()

.lambda()

.eq(SysMerchantVersion::getMerchantId, merchantId));

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:【TSP问题】基于狼群算法求解旅行商问题含Matlab源码
下一篇:Python基础学习-4.函数与语句(Python函数笔记)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~