日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

關于Spring AOP使用時的一些問題匯總

瀏覽:171日期:2023-08-06 10:59:49

在使用AOP的時候遇到了一些問題,特此記錄一下

首先寫一個常用的AOP切片

切片類AopLog

package com.mantis.aop.aspect;import com.fasterxml.jackson.databind.ObjectMapper;import com.mantis.aop.common.util.DataUtil;import eu.bitwalker.useragentutils.UserAgent;import org.aspectj.lang.JoinPoint;import org.aspectj.lang.ProceedingJoinPoint;import org.aspectj.lang.annotation.*;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.stereotype.Component;import org.springframework.validation.BeanPropertyBindingResult;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import java.util.ArrayList;import java.util.Arrays;import java.util.Enumeration;import java.util.List;import java.util.stream.Collectors;/** * @Description:執行順序 正常順序 Around Before Method.invoke Around After AfterReturning * 異常順序 Around Before Method.invoke After AfterThrowing * @author: wei.wang * @since: 2020/4/4 13:47 * @history: 1.2020/4/4 created by wei.wang */@Aspect@Componentpublic class AopLog { private static Logger logger = LoggerFactory.getLogger(AopLog.class); /** * 定義切點,切點為com.smec.fin.controller包和子包里任意方法的執行和service層所有方法的執行 */ @Pointcut('execution(public * com.mantis.aop.controller..*.*(..))') public void log() { // 定義切點 } /** * 定義切點,切點為com.smec.fin.controller包和子包里任意方法的執行和service層所有方法的執行 */ @Pointcut('execution(public * com.mantis.aop.service.impl..*.*(..))') public void log2() { // 定義切點 } /** * 環繞通知 * * @param point * @return * @throws Throwable */ @Around('log2()') public Object aroundLog(ProceedingJoinPoint point) throws Throwable { logger.info('開始執行環繞操作'); Object result = point.proceed(); logger.info('執行環繞操作結束,返回值:{}', result); return result; }}

服務類AopServiceImpl

package com.mantis.aop.service.impl;import com.mantis.aop.service.AopService;import org.springframework.aop.framework.AopContext;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Service;/** * @Description: * @author: wei.wang * @since: 2020/10/24 12:45 * @history: 1.2020/10/24 created by wei.wang */@Servicepublic class AopServiceImpl implements AopService { @Override public void testAop(String str) { System.out.println('com.mantis.aop.service.AopService.AopServiceImpl.testAop' + str); this.testAop2('testFinalMethod'); } @Override public void testAop2(String str) { //this.testFinalMethod('testFinalMethod'); System.out.println('com.mantis.aop.service.AopService.AopServiceImpl.' + str); } public final void testFinalMethod(String str) { System.out.println('com.mantis.aop.service.AopService.AopServiceImpl.testFinalMethod' + str); } public void testFinalMethod2(String str) { System.out.println('com.mantis.aop.service.AopService.AopServiceImpl.testFinalMethod' + str); }}

1.同方法運行問題

在使用AOP時我們發現存在同類中調用時切點失效問題,在執行時我們發現只執行了testAop的切點,testAop2的切點沒有執行,這是因為經過AOP代理后的對象都已經不是原來的對象了,而是加入了增強方法的代理對象,使用代理對象調用時可以執行增強方法,但是這里是使用this調用的,也就是AopServiceImpl,因為不是代理對象就沒有增強方法。

2020-10-24 13:31:06.261 INFO 13344 --- [nio-9000-exec-1] com.mantis.aop.controller.AopController : 方法開始執行2020-10-24 13:31:06.264 INFO 13344 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 開始執行環繞操作com.mantis.aop.service.AopService.AopServiceImpl.testAoptest2com.mantis.aop.service.AopService.AopServiceImpl.testFinalMethod2020-10-24 13:31:06.274 INFO 13344 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 執行環繞操作結束,返回值:null

用@Autowired或Resource引入自身依賴

使用注解方法引入自身代理依賴,注意使用構造的方式會有循環依賴問題

@Autowired AopServiceImpl aopService; @Override public void testAop(String str) { System.out.println('com.mantis.aop.service.AopService.AopServiceImpl.testAop' + str); aopService.testAop2('testFinalMethod'); System.out.println(); }

2020-10-24 13:36:33.477 INFO 12528 --- [nio-9000-exec-1] com.mantis.aop.controller.AopController : 方法開始執行2020-10-24 13:36:33.480 INFO 12528 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 開始執行環繞操作com.mantis.aop.service.AopService.AopServiceImpl.testAoptest22020-10-24 13:36:33.488 INFO 12528 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 開始執行環繞操作com.mantis.aop.service.AopService.AopServiceImpl.testFinalMethod2020-10-24 13:36:33.488 INFO 12528 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 執行環繞操作結束,返回值:null2020-10-24 13:36:33.490 INFO 12528 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 執行環繞操作結束,返回值:null

開啟暴露代理類,AopContext.currentProxy()方式獲取代理類

通過暴露代理類方式,實際原理是把代理類添加到當前請求的ThreadLocal里面,然后在使用時從ThreadLocal中獲取代理類,再調用對應的方法

在主方法上加入@EnableAspectJAutoProxy(exposeProxy=true),然后從AOP上下文中獲取代理

@Override public void testAop(String str) { System.out.println('com.mantis.aop.service.AopService.AopServiceImpl.testAop' + str); AopServiceImpl service = AopContext.currentProxy() != null ? (AopServiceImpl) AopContext.currentProxy() : this; service.testAop2('testFinalMethod'); System.out.println(); }

2020-10-24 13:38:31.031 INFO 18828 --- [nio-9000-exec-1] com.mantis.aop.controller.AopController : 方法開始執行2020-10-24 13:38:31.035 INFO 18828 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 開始執行環繞操作com.mantis.aop.service.AopService.AopServiceImpl.testAoptest22020-10-24 13:38:31.047 INFO 18828 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 開始執行環繞操作com.mantis.aop.service.AopService.AopServiceImpl.testFinalMethod2020-10-24 13:38:31.048 INFO 18828 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 執行環繞操作結束,返回值:null2020-10-24 13:38:31.050 INFO 18828 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 執行環繞操作結束,返回值:null

2.final關鍵字問題

Spring AOP默認使用cglib,會生成目標對象的子類代理對象。調用目標對象的方法,實際上是調用代理對象的方法。由于子類能夠繼承父類的方法,因此一般情況下目標類的方法,代理對象都會有。但是當目標類中某個方法帶有final關鍵字時,這個方法不能被重寫,因此代理對象中沒有這個方法,因此會調用目標對象的方法。

帶final關鍵字

因為testFinalMethod方法中存在final關鍵字,導致無法重寫,結果代理對象就無法生成這個方法,因此調用目標對象方法,導致沒有被增強

@Override public void testAop(String str) { System.out.println('com.mantis.aop.service.AopService.AopServiceImpl.testAop' + str); AopServiceImpl service = AopContext.currentProxy() != null ? (AopServiceImpl) AopContext.currentProxy() : this; service.testFinalMethod('testFinalMethod'); System.out.println(); } public final void testFinalMethod(String str) { System.out.println('com.mantis.aop.service.AopService.AopServiceImpl.testFinalMethod' + str); }

2020-10-24 13:47:46.907 INFO 15204 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 開始執行環繞操作com.mantis.aop.service.AopService.AopServiceImpl.testAoptest2com.mantis.aop.service.AopService.AopServiceImpl.testFinalMethodtestFinalMethod2020-10-24 13:47:46.916 INFO 15204 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 執行環繞操作結束,返回值:null

不帶final關鍵字

因為testFinalMethod方法中不存在final關鍵字,所以正常執行增強。

@Override public void testAop(String str) { System.out.println('com.mantis.aop.service.AopService.AopServiceImpl.testAop' + str); AopServiceImpl service = AopContext.currentProxy() != null ? (AopServiceImpl) AopContext.currentProxy() : this; service.testFinalMethod2('testFinalMethod'); System.out.println(); } public final void testFinalMethod2(String str) { System.out.println('com.mantis.aop.service.AopService.AopServiceImpl.testFinalMethod' + str); }

2020-10-24 13:50:51.018 INFO 13532 --- [nio-9000-exec-2] com.mantis.aop.controller.AopController : 方法開始執行2020-10-24 13:50:51.021 INFO 13532 --- [nio-9000-exec-2] com.mantis.aop.aspect.AopLog : 開始執行環繞操作com.mantis.aop.service.AopService.AopServiceImpl.testAoptest22020-10-24 13:50:51.029 INFO 13532 --- [nio-9000-exec-2] com.mantis.aop.aspect.AopLog : 開始執行環繞操作com.mantis.aop.service.AopService.AopServiceImpl.testFinalMethodtestFinalMethod2020-10-24 13:50:51.030 INFO 13532 --- [nio-9000-exec-2] com.mantis.aop.aspect.AopLog : 執行環繞操作結束,返回值:null2020-10-24 13:50:51.031 INFO 13532 --- [nio-9000-exec-2] com.mantis.aop.aspect.AopLog : 執行環繞操作結束,返回值:null

總結

到此這篇關于Spring AOP使用時的一些問題匯總的文章就介紹到這了,更多相關Spring AOP使用時的問題內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
美女精品在线观看| 日韩成人精品一区二区三区| 欧美成人一二区| 久久国际精品| 亚洲精品极品| 一区二区电影在线观看| 亚洲日本国产| 欧美一区自拍| 国产精品一国产精品k频道56| 欧美日韩伊人| 麻豆精品蜜桃视频网站| 国产一区二区三区视频在线| 精品久久久久中文字幕小说| 视频在线不卡免费观看| 亚洲一区资源| 国户精品久久久久久久久久久不卡 | 亚洲大片在线| 亚洲婷婷免费| 亚洲在线一区| 日本不卡在线视频| 另类综合日韩欧美亚洲| 亚洲黄色网址| 在线亚洲自拍| 青草国产精品久久久久久| 国产伦理一区| av资源亚洲| 狠狠爱www人成狠狠爱综合网| 亚洲一区二区小说| 欧美精品三级在线| 国产白浆在线免费观看| 伊人精品视频| 国产日产精品_国产精品毛片 | 98精品视频| 亚洲激情婷婷| 7777精品| 国产粉嫩在线观看| 久久午夜精品一区二区| 国产调教精品| 97精品视频在线看| 午夜在线一区二区| 久久99免费视频| 婷婷精品视频| 日韩精品免费观看视频| xxxxx性欧美特大| 视频一区免费在线观看| 久久国产尿小便嘘嘘| 日韩国产欧美一区二区| 亚洲资源在线| 国产高清不卡| 亚洲精品观看| 国产一区二区三区天码| 性一交一乱一区二区洋洋av| 国产精品主播| 99精品视频在线观看免费播放| 亚洲精品无吗| av一区在线| 欧美在线观看天堂一区二区三区| 久久91导航| 久久国产乱子精品免费女| 久久久一二三| 国产探花一区| 一区二区自拍| 国产91在线播放精品| 亚洲欧美视频| 国内精品伊人| 日韩中文字幕| 亚洲高清毛片| 精品精品99| 亚洲人www| 成人国产精品| 欧美视频久久| 视频一区二区不卡| 91精品国产调教在线观看| 国产黄色一区| 亚洲毛片在线| 欧美日韩精品免费观看视频完整| 麻豆极品一区二区三区| 一区二区三区国产在线| 日韩精品首页| 精品72久久久久中文字幕| 偷拍亚洲精品| 一区在线免费观看| 国产传媒在线观看| 国产精品久久久久久久免费软件| 日本精品影院| 色欧美自拍视频| 你懂的网址国产 欧美| 四虎精品一区二区免费| 怡红院精品视频在线观看极品| 色婷婷亚洲mv天堂mv在影片| 亚洲精品少妇| 亚洲精品一级二级| 国产精品一国产精品k频道56| 蜜桃视频在线观看一区二区| 欧美~级网站不卡| 国产精品久久久久久久久妇女| 欧美日韩一区二区三区在线电影| 免费视频一区二区| 亚洲一区成人| 国产精东传媒成人av电影| 亚洲深深色噜噜狠狠爱网站| 亚洲精品电影| 国产高清一区| 日本少妇一区| 久久久一本精品| 在线手机中文字幕| 精品国产乱码久久久| 麻豆精品在线| 久久精品国产网站| 国产精品一区二区三区av| 一区二区国产精品| 首页亚洲欧美制服丝腿| 99pao成人国产永久免费视频| 国产 日韩 欧美一区| 老司机免费视频一区二区| 欧美精品国产一区| 亚洲精品美女| 人人爽香蕉精品| 亚洲丝袜美腿一区| 亚洲欧洲日韩| 午夜电影一区| 亚洲欧美日韩国产一区二区| 日韩午夜av| 日韩中文字幕1| 综合激情视频| 亚洲精品影院在线观看| 亚洲一级在线| 天堂av在线一区| 亚洲精品在线a| 日韩在线黄色| 欧美日韩xxxx| 日本少妇一区二区| 国产日韩在线观看视频| 美女视频免费精品| 在线精品亚洲欧美日韩国产| 999国产精品| 九九综合九九| 蜜桃视频一区二区三区| 久久精品99国产精品| 国产欧美日韩影院| 美女国产精品久久久| 国产一区二区三区天码| 最新中文字幕在线播放| 久久在线视频免费观看| 国产一区久久| 亚洲毛片在线| 国产精品天天看天天狠| 国产成人精品免费视| 99久久精品国产亚洲精品| 亚洲一区日本| 久久国产欧美日韩精品| av中文字幕在线观看第一页| 99久久婷婷| 久久亚洲国产精品一区二区| 久久国内精品自在自线400部| 免费在线日韩av| 日韩一区二区三区免费| 亚洲欧洲一区二区天堂久久| 天海翼亚洲一区二区三区| 日本va欧美va瓶| 久久久免费人体| 国产综合亚洲精品一区二| 免费在线欧美视频| 麻豆91精品视频| 欧洲毛片在线视频免费观看| 日韩精彩视频在线观看| 国产精品yjizz视频网| 六月婷婷一区| 精品高清久久| 亚洲在线成人| 免费在线亚洲欧美| 图片区亚洲欧美小说区| 日韩高清中文字幕一区| www.51av欧美视频| 欧美日韩精品免费观看视欧美高清免费大片 | 成人看片网站| 中文字幕日韩亚洲| 91亚洲自偷观看高清| 老牛国产精品一区的观看方式| 日韩和欧美一区二区三区| 国产成人免费精品| 免费观看日韩电影| 国产成人精品一区二区三区在线| 日韩午夜高潮| 麻豆国产精品| 久久亚洲风情| 国产精品xx| 蜜桃一区二区三区在线观看| 精品久久久久中文字幕小说| 老鸭窝亚洲一区二区三区| 精品国产不卡| 六月丁香综合| 国产精品黑丝在线播放| 中文字幕一区二区av| 久久国产乱子精品免费女| 久久久精品午夜少妇| 国产欧美一区二区精品久久久| 1024精品一区二区三区| 免费一级欧美片在线观看网站 | 在线精品小视频|