spring使用aspect注解切面不起作用的排查過程及解決
今天做spring使用aspect注解demo,發(fā)現(xiàn)不起作用,問題排查如下:
1.程序正常啟動,說明jar包依賴沒有問題
2.debug程序不進(jìn)入切面,有可能是路徑問題,根據(jù)這個思路,果真是路徑問題,在切面配置類的使用@ComponentScan的路徑寫錯了。
掃描的路徑為:注解類、切面類及service的上一層目錄即可,假設(shè)項目的結(jié)構(gòu)如下:
則@ComponenScan('demo.com.nrt')即可
SpringBoot切面@aspect--- 注解在嵌套方法不生效的問題例如在service中方法如下
@PermissionAop @Override public List<PoiPermission> getList() {List<PoiPermission> list = this.list();return list; } @Override public void test(){this.getList();System.out.println(''); }
controller中調(diào)用test()方法,test方法中調(diào)用切面方法,切面不生效,無法進(jìn)入切面。
使用如下方式可解決該問題(啟動類上需要添加
@EnableAspectJAutoProxy(exposeProxy = true))
@PermissionAop @Override public List<PoiPermission> getList() {List<PoiPermission> list = this.list();return list; } @Override public void test(){IPoiPermissionService service = (IPoiPermissionService) AopContext.currentProxy();service.getList();System.out.println(''); }
其中IPoiPermissionService為該service類實(shí)現(xiàn)的接口。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
