久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

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

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

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

在使用AOP的時(shí)候遇到了一些問(wèn)題,特此記錄一下

首先寫一個(gè)常用的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); /** * 定義切點(diǎn),切點(diǎn)為com.smec.fin.controller包和子包里任意方法的執(zhí)行和service層所有方法的執(zhí)行 */ @Pointcut('execution(public * com.mantis.aop.controller..*.*(..))') public void log() { // 定義切點(diǎn) } /** * 定義切點(diǎn),切點(diǎn)為com.smec.fin.controller包和子包里任意方法的執(zhí)行和service層所有方法的執(zhí)行 */ @Pointcut('execution(public * com.mantis.aop.service.impl..*.*(..))') public void log2() { // 定義切點(diǎn) } /** * 環(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.同方法運(yùn)行問(wèn)題

在使用AOP時(shí)我們發(fā)現(xiàn)存在同類中調(diào)用時(shí)切點(diǎn)失效問(wèn)題,在執(zhí)行時(shí)我們發(fā)現(xiàn)只執(zhí)行了testAop的切點(diǎn),testAop2的切點(diǎn)沒(méi)有執(zhí)行,這是因?yàn)榻?jīng)過(guò)AOP代理后的對(duì)象都已經(jīng)不是原來(lái)的對(duì)象了,而是加入了增強(qiáng)方法的代理對(duì)象,使用代理對(duì)象調(diào)用時(shí)可以執(zhí)行增強(qiáng)方法,但是這里是使用this調(diào)用的,也就是AopServiceImpl,因?yàn)椴皇谴韺?duì)象就沒(méi)有增強(qiáng)方法。

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ì)有循環(huán)依賴問(wè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()方式獲取代理類

通過(guò)暴露代理類方式,實(shí)際原理是把代理類添加到當(dāng)前請(qǐng)求的ThreadLocal里面,然后在使用時(shí)從ThreadLocal中獲取代理類,再調(diào)用對(duì)應(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)鍵字問(wèn)題

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

帶final關(guān)鍵字

因?yàn)閠estFinalMethod方法中存在final關(guān)鍵字,導(dǎo)致無(wú)法重寫,結(jié)果代理對(duì)象就無(wú)法生成這個(gè)方法,因此調(diào)用目標(biāo)對(duì)象方法,導(dǎo)致沒(méi)有被增強(qiáng)

@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)鍵字

因?yàn)閠estFinalMethod方法中不存在final關(guān)鍵字,所以正常執(zhí)行增強(qiáng)。

@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使用時(shí)的一些問(wèn)題匯總的文章就介紹到這了,更多相關(guān)Spring AOP使用時(shí)的問(wèn)題內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 国产精品国产三级国产aⅴ无密码 | 国产精品99久久久久久久vr | 国产成人精品午夜视频免费 | 欧美一区二区三区xxxx监狱 | 久久久久女人精品毛片九一韩国 | 国产福利在线免费 | 久久精品视频亚洲 | 免费看一区二区三区 | 太平公主一级艳史播放高清 | 国内自拍视频网 | 天天看天天爽 | av网站推荐 | 国产精品一区二区三区在线 | 国产一区二区三区免费观看 | 日韩在线中文字幕 | 嫩草视频在线播放 | 女人夜夜春 | 精品一区免费观看 | 日韩在线精品视频 | 亚洲精品久久 | 国产精品久久久久影院色老大 | 91嫩草在线 | 成人免费精品视频 | 亚洲天堂一区二区 | 亚洲欧美国产精品久久 | 国产成人午夜视频 | 午夜视频| 中文字幕亚洲精品 | 2021最新热播中文字幕-第1页-看片视频 青青青久草 | 久久亚洲天堂 | 国产日韩欧美在线 | 欧美日一区二区 | 蜜桃comaaa| av一级毛片| 欧美v片| 成人在线影视 | 国产农村妇女精品一二区 | 精品亚洲一区二区三区四区五区 | 女人毛片a毛片久久人人 | 色综合一区二区三区 | 久久中文字幕一区 |