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

您的位置:首頁技術(shù)文章
文章詳情頁

關(guān)于Spring AOP使用時的一些問題匯總

瀏覽:174日期: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:執(zhí)行順序 正常順序 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包和子包里任意方法的執(zhí)行和service層所有方法的執(zhí)行 */ @Pointcut('execution(public * com.mantis.aop.controller..*.*(..))') public void log() { // 定義切點 } /** * 定義切點,切點為com.smec.fin.controller包和子包里任意方法的執(zhí)行和service層所有方法的執(zhí)行 */ @Pointcut('execution(public * com.mantis.aop.service.impl..*.*(..))') public void log2() { // 定義切點 } /** * 環(huán)繞通知 * * @param point * @return * @throws Throwable */ @Around('log2()') public Object aroundLog(ProceedingJoinPoint point) throws Throwable { logger.info('開始執(zhí)行環(huán)繞操作'); Object result = point.proceed(); logger.info('執(zhí)行環(huán)繞操作結(jié)束,返回值:{}', result); return result; }}

服務(wù)類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時我們發(fā)現(xiàn)存在同類中調(diào)用時切點失效問題,在執(zhí)行時我們發(fā)現(xiàn)只執(zhí)行了testAop的切點,testAop2的切點沒有執(zhí)行,這是因為經(jīng)過AOP代理后的對象都已經(jīng)不是原來的對象了,而是加入了增強方法的代理對象,使用代理對象調(diào)用時可以執(zhí)行增強方法,但是這里是使用this調(diào)用的,也就是AopServiceImpl,因為不是代理對象就沒有增強方法。

2020-10-24 13:31:06.261 INFO 13344 --- [nio-9000-exec-1] com.mantis.aop.controller.AopController : 方法開始執(zhí)行2020-10-24 13:31:06.264 INFO 13344 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 開始執(zhí)行環(huán)繞操作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 : 執(zhí)行環(huán)繞操作結(jié)束,返回值:null

用@Autowired或Resource引入自身依賴

使用注解方法引入自身代理依賴,注意使用構(gòu)造的方式會有循環(huán)依賴問題

@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 : 方法開始執(zhí)行2020-10-24 13:36:33.480 INFO 12528 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 開始執(zhí)行環(huán)繞操作com.mantis.aop.service.AopService.AopServiceImpl.testAoptest22020-10-24 13:36:33.488 INFO 12528 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 開始執(zhí)行環(huán)繞操作com.mantis.aop.service.AopService.AopServiceImpl.testFinalMethod2020-10-24 13:36:33.488 INFO 12528 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 執(zhí)行環(huán)繞操作結(jié)束,返回值:null2020-10-24 13:36:33.490 INFO 12528 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 執(zhí)行環(huán)繞操作結(jié)束,返回值:null

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

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

在主方法上加入@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 : 方法開始執(zhí)行2020-10-24 13:38:31.035 INFO 18828 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 開始執(zhí)行環(huán)繞操作com.mantis.aop.service.AopService.AopServiceImpl.testAoptest22020-10-24 13:38:31.047 INFO 18828 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 開始執(zhí)行環(huán)繞操作com.mantis.aop.service.AopService.AopServiceImpl.testFinalMethod2020-10-24 13:38:31.048 INFO 18828 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 執(zhí)行環(huán)繞操作結(jié)束,返回值:null2020-10-24 13:38:31.050 INFO 18828 --- [nio-9000-exec-1] com.mantis.aop.aspect.AopLog : 執(zhí)行環(huán)繞操作結(jié)束,返回值:null

2.final關(guān)鍵字問題

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

帶final關(guān)鍵字

因為testFinalMethod方法中存在final關(guān)鍵字,導(dǎo)致無法重寫,結(jié)果代理對象就無法生成這個方法,因此調(diào)用目標對象方法,導(dǎo)致沒有被增強

@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 : 開始執(zhí)行環(huán)繞操作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 : 執(zhí)行環(huán)繞操作結(jié)束,返回值:null

不帶final關(guān)鍵字

因為testFinalMethod方法中不存在final關(guān)鍵字,所以正常執(zhí)行增強。

@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 : 方法開始執(zhí)行2020-10-24 13:50:51.021 INFO 13532 --- [nio-9000-exec-2] com.mantis.aop.aspect.AopLog : 開始執(zhí)行環(huán)繞操作com.mantis.aop.service.AopService.AopServiceImpl.testAoptest22020-10-24 13:50:51.029 INFO 13532 --- [nio-9000-exec-2] com.mantis.aop.aspect.AopLog : 開始執(zhí)行環(huán)繞操作com.mantis.aop.service.AopService.AopServiceImpl.testFinalMethodtestFinalMethod2020-10-24 13:50:51.030 INFO 13532 --- [nio-9000-exec-2] com.mantis.aop.aspect.AopLog : 執(zhí)行環(huán)繞操作結(jié)束,返回值:null2020-10-24 13:50:51.031 INFO 13532 --- [nio-9000-exec-2] com.mantis.aop.aspect.AopLog : 執(zhí)行環(huán)繞操作結(jié)束,返回值:null

總結(jié)

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

標簽: Spring
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
91亚洲无吗| 国产精品jk白丝蜜臀av小说| 国产精品www.| 国产乱子精品一区二区在线观看| 日韩激情精品| 中文字幕av一区二区三区人| 亚洲欧美日韩在线观看a三区| 老鸭窝亚洲一区二区三区| 好看不卡的中文字幕| 在线观看免费一区二区| 在线视频日韩| 中文字幕av一区二区三区四区| 日本亚洲三级在线| 国产日韩欧美三区| 精品一区二区三区的国产在线观看| 美女精品一区二区| 日韩a一区二区| 国产精品专区免费| 久久久久久免费视频| 激情综合网五月| 宅男在线一区| 亚洲精选av| 麻豆精品新av中文字幕| 日韩免费看片| 亚洲精品1区| 日本在线不卡视频一二三区| 国产精品黄网站| а√天堂8资源中文在线| 久久国产亚洲精品| 亚洲在线免费| 国产乱人伦丫前精品视频| 国产精品精品| 国产一级一区二区| 欧美一级网站| 中文在线资源| 视频在线观看91| 欧美在线首页| 欧美激情国产在线| 性色av一区二区怡红| 欧美日韩中文| 成人免费电影网址| 中文字幕一区二区三区在线视频| 国产精品亲子伦av一区二区三区| 日本少妇一区| 日本不卡不码高清免费观看| 国产一区二区三区不卡视频网站| 国产在线成人| 久久精品97| 99久久久久国产精品| 欧美一级全黄| 久久久久国产一区二区| 蜜桃视频一区二区| 国产精品久久久久久久久妇女| 亚洲少妇自拍| 精品一区二区三区中文字幕| 午夜日韩福利| 久久久精品国产**网站| 欧美日韩国产探花| 久久av影视| 美日韩精品视频| 韩国一区二区三区视频| 视频一区二区国产| 激情黄产视频在线免费观看| 香蕉久久一区| 久久精品国产www456c0m| 日韩精品视频在线看| 秋霞国产精品| 国产精品2区| 免费一区二区视频| 亚洲成人二区| 麻豆一区二区三| 日韩专区视频网站| 91亚洲国产成人久久精品| 日本不卡高清视频| 精品欧美久久| 91中文字幕精品永久在线| 日本不卡一二三区黄网| 免费成人网www| 久久精品一区二区国产| 亚洲性视频在线| 欧美精品高清| 久久99精品久久久野外观看| 蜜臀久久久久久久| 国产在线日韩| 日韩国产一区二区三区| 国产精品久久久久久久久免费高清 | 久久av一区| 日韩不卡视频在线观看| 国产精品一区二区三区美女| 在线一区二区三区视频| 欧美亚洲精品在线| 国产黄大片在线观看| 国产伦精品一区二区三区视频| 亚洲精品福利| 玖玖精品视频| 九一精品国产| 国产99久久久国产精品成人免费| 国产精品大片免费观看| 午夜视频一区二区在线观看| 欧美日韩国产一区精品一区| 久久精品成人| 群体交乱之放荡娇妻一区二区| a天堂资源在线| 里番精品3d一二三区| 国产欧美日韩精品高清二区综合区 | 首页国产精品| 欧美成人精品一级| 国产日产一区| 日韩av网站免费在线| 日韩精品中文字幕一区二区| 男人的天堂久久精品| 国产精品人人爽人人做我的可爱 | 97精品国产福利一区二区三区| 国产精品啊v在线| 欧美日韩午夜| 91av一区| 欧美极品中文字幕| 麻豆国产精品| 久久久久免费| 亚洲不卡系列| 91高清一区| 久久视频一区| 亚洲天堂黄色| 在线看片不卡| 免费国产亚洲视频| 亚洲免费一区三区| 亚洲ab电影| 青青草精品视频| 欧美日韩一区二区三区不卡视频| 国产欧美啪啪| 国产福利资源一区| 国产一区二区三区四区五区| 国内精品伊人| 亚洲免费福利| 亚洲成人精品| 免费日韩精品中文字幕视频在线| 蜜桃久久精品一区二区| 四季av一区二区凹凸精品| 精品国产免费人成网站| 精品亚洲美女网站| 免费日韩av| 久久精品72免费观看| 精品国产午夜| 99久久精品国产亚洲精品| 日韩一区二区免费看| 先锋亚洲精品| 日韩午夜视频在线| 欧美国产视频| 日韩欧美少妇| 伊人www22综合色| 国产精品一区二区三区av麻| 日韩av在线播放网址| 亚洲精品一区二区妖精| 午夜亚洲福利| 久久精品九色| 国产99精品| 午夜电影一区| 精品国产美女a久久9999| 精品日韩视频| 视频在线观看91| 日韩精品久久久久久| 久久精品一本| 亚洲手机视频| 日本欧美大码aⅴ在线播放| 久久精品一区| 欧美高清一区| 久久国产日韩欧美精品| 女生影院久久| 亚洲资源网站| 精品国内亚洲2022精品成人| 三级精品视频| 日韩精品视频网| 欧美好骚综合网| 视频精品一区二区| 麻豆精品蜜桃视频网站| 久久久久久久久久久妇女| 日韩中文字幕视频网| 日韩欧美国产精品综合嫩v| 国产精品日韩久久久| 国产高清亚洲| 国产精品社区| 久久影院资源站| 国产亚洲网站| 国产一区二区三区日韩精品| 亚洲欧美久久| 日本一区二区高清不卡| 美女网站久久| 91免费精品| 午夜久久av | 国产免费久久| 欧美日一区二区| 国产日韩欧美一区二区三区 | 久久aⅴ国产紧身牛仔裤| 欧美激情五月| 老牛影视一区二区三区| а√天堂8资源中文在线| 亚洲乱码视频| 国产在线观看www| 亚洲精品国产精品粉嫩| 另类中文字幕国产精品|