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

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

Spring AOP 實(shí)現(xiàn)自定義注解的示例

瀏覽:97日期:2023-07-18 13:35:04

自工作后,除了一些小項(xiàng)目配置事務(wù)使用過 AOP,真正自己寫 AOP 機(jī)會(huì)很少,另一方面在工作后還沒有寫過自定義注解,一直很好奇注解是怎么實(shí)現(xiàn)他想要的功能的,剛好做項(xiàng)目的時(shí)候,經(jīng)常有人日志打得不夠全,經(jīng)常出現(xiàn)問題了,查日志的才發(fā)現(xiàn)忘記打了,所以趁此機(jī)會(huì),搜了一些資料,用 AOP + 自定義注解,實(shí)現(xiàn)請求攔截,自定義打日志,玩一下這兩個(gè)東西,以下是自己完的一個(gè)小例子,也供需要的同學(xué)參考。

1. 注解如下:

package cn.bridgeli.demo.annotation; import java.lang.annotation.ElementType;import java.lang.annotation.Retention;import java.lang.annotation.RetentionPolicy;import java.lang.annotation.Target; /** * @author bridgeli */@Target(ElementType.METHOD)@Retention(RetentionPolicy.RUNTIME)public @interface MyLog { /** * 方法描述 * * @return */ String desc() default '';}2. 切面

package cn.bridgeli.demo.annotation; import cn.bridgeli.utils.AuthorizeUtil;import cn.bridgeli.entity.Principal;import lombok.extern.slf4j.Slf4j;import org.apache.commons.lang3.StringUtils;import org.aspectj.lang.ProceedingJoinPoint;import org.aspectj.lang.annotation.Around;import org.aspectj.lang.annotation.Aspect;import org.aspectj.lang.annotation.Pointcut;import org.springframework.stereotype.Component; /** * @author bridgeli * 1. 這是一個(gè)切面類 */@Aspect@Component@Slf4jpublic class MyLogAspect { /** * 2. PointCut表示這是一個(gè)切點(diǎn),@annotation表示這個(gè)切點(diǎn)切到一個(gè)注解上,后面帶該注解的全類名 * 切面最主要的就是切點(diǎn),所有的故事都圍繞切點(diǎn)發(fā)生 * logPointCut()代表切點(diǎn)名稱 */ @Pointcut('@annotation(cn.bridgeli.demo.annotation.MyLog)') public void logPointCut() { } /** * 3. 環(huán)繞通知 * * @param joinPoint * @param myLog * @return */ @Around(value = 'logPointCut() && @annotation(myLog)', argNames = 'joinPoint,myLog') public Object logAround(ProceedingJoinPoint joinPoint, MyLog myLog) {// 獲取方法名String methodFullPathName = joinPoint.getTarget().getClass().getName() + '#' + joinPoint.getSignature().getName(); // 獲取參數(shù)String params = StringUtils.join(joinPoint.getArgs(), ';'); Principal currentUser = AuthorizeUtil.getCurrentUser();log.info('當(dāng)前登陸用戶:' + (null == currentUser ? '' : currentUser.toString()) + ',進(jìn)入 [ ' + methodFullPathName + ' ] 方法, 方法的描述:' + myLog.desc() + ',參數(shù)為:' + params); // 繼續(xù)執(zhí)行方法long startTime = System.currentTimeMillis();Object result = null;try { result = joinPoint.proceed();} catch (Throwable e) { log.error('切面執(zhí)行報(bào)錯(cuò),參數(shù):' + params, e);}long elapsed = System.currentTimeMillis() - startTime; log.info('[ ' + methodFullPathName + ' ] 方法執(zhí)行結(jié)束,返回值為:' + (null == result ? '' : result.toString()) + ',用時(shí):' + elapsed); return result; }}

然后只需要在想使用的地方 @MyLog 就可以了,當(dāng)然也可以加上 @MyLog(desc = “這是方法描述”),這樣打出來的日志還會(huì)有方法是做什么的,別人看日志的時(shí)候能夠一目了然。

需要說明的是,我在寫這個(gè)切面的時(shí)候遇到的一個(gè)小問題,在網(wǎng)上看 AOP 的注解,很多人在舉例子的時(shí)候都是不關(guān)注 @Around 的返回值,所以方法的返回值都寫的 void,因?yàn)槲覍?AOP 也不是很熟,所以當(dāng)時(shí)同樣寫了一個(gè) void,結(jié)果寫好一測試,返回?cái)r截也正常,日志也打印了,被攔截的方法執(zhí)行也挺正常,但是就是沒有了返回值,當(dāng)時(shí)還很奇怪,然后隨便試了下返回值改成 Object,竟然對了,所以這是一個(gè)小坑,也是很多人沒有說明的一點(diǎn),大家可以注意下,其實(shí)這個(gè)問題也很容易想到,@Around 是環(huán)繞攔截,在執(zhí)行完被攔截的方法之后,會(huì)繼續(xù)執(zhí)行切面方法,如果切面方法沒有返回值,那么自然而然就沒有返回值了,同理 @After 攔截個(gè)人猜測也應(yīng)該有同樣的問題,大家可以測試下。

以上就是Spring AOP 實(shí)現(xiàn)自定義注解的示例的詳細(xì)內(nèi)容,更多關(guān)于Spring AOP 實(shí)現(xiàn)自定義注解的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Spring
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久影院一区二区三区| 亚洲91网站| 高清av一区| 精品亚洲成人| 国产精品毛片久久| 久久精品播放| 伊人久久亚洲热| 亚洲一区二区三区四区电影| 亚洲三级在线| 国产剧情在线观看一区| 精品视频一二| 国产精品久久久久av电视剧| 蜜桃国内精品久久久久软件9| 欧美sss在线视频| 一级欧洲+日本+国产| 免费久久99精品国产自在现线| 先锋影音国产一区| 午夜亚洲福利| 国产精品午夜一区二区三区| 精品国内亚洲2022精品成人| 在线人成日本视频| 亚洲天堂黄色| 亚洲免费专区| 精品香蕉视频| 亚洲韩日在线| 亚洲最大av| 嫩草伊人久久精品少妇av杨幂| 国产资源在线观看入口av| 91tv亚洲精品香蕉国产一区| 亚洲欧洲一区| 国产调教精品| 日韩毛片在线| 蜜桃视频免费观看一区| 国产精品色婷婷在线观看| 91亚洲国产| 亚洲综合三区| 欧美精品第一区| 国产中文一区| 国产欧美一区二区精品久久久 | 蜜臀久久99精品久久久画质超高清| 亚洲天堂av资源在线观看| 国产精品永久| 亚洲精品2区| 国产精品欧美日韩一区| 成人av三级| 亚洲精品乱码| 日韩国产一区| 日日夜夜免费精品| 国产成人精品亚洲线观看| 最新日韩av| 国产黄色精品| 九九综合九九| 国产精品欧美三级在线观看| 欧美日韩色图| 国产欧美日韩一级| 久久久久免费av| 91精品国产自产精品男人的天堂 | 夜夜嗨一区二区| 美女久久久精品| 美女久久网站| 日本免费一区二区三区四区| 天堂va在线高清一区| 久久男女视频| 欧美日韩亚洲一区二区三区在线| 999久久久精品国产| 国产精品一级| 亚洲欧美日韩一区在线观看| 国产不卡人人| 国产伦一区二区三区| 中文精品视频| 国产va在线视频| 国产三级精品三级在线观看国产| 成人av动漫在线观看| 国产精品第一| 亚洲日本三级| 一级欧洲+日本+国产| 精品一区二区三区在线观看视频 | 欧美资源在线| 日韩电影免费在线观看| 国产探花一区| 亚洲一区二区三区四区电影| 久久久久免费av| 久久这里只有| 日本午夜免费一区二区 | 综合国产精品| 午夜欧美精品| 日韩精品一卡| 久久亚洲人体| 欧美三级第一页| 久久午夜精品| 99久久精品费精品国产| 给我免费播放日韩视频| 欧美天堂一区| 日韩毛片一区| 中文字幕av一区二区三区人| 不卡视频在线| 久久中文视频| 色老板在线视频一区二区| 国产一区二区三区亚洲| 国产精品任我爽爆在线播放| 18国产精品| 日韩和欧美一区二区三区| 亚洲三区欧美一区国产二区| 视频一区二区不卡| 香蕉久久久久久久av网站| 国产99久久| 欧美色图一区| 国产在线欧美| 亚洲激情二区| 久久xxxx| 亚洲资源网站| 日韩精选在线| 日韩精品视频中文字幕| 日韩在线网址| 91福利精品在线观看| 中文字幕日本一区| 亚洲+小说+欧美+激情+另类| 亚洲青青久久| 日韩有吗在线观看| 青草久久视频| 日本免费在线视频不卡一不卡二| 日韩美女精品| 国产欧美日韩在线一区二区| 国产精品一区高清| 国产欧美啪啪| 久久xxx视频| 精品国产一区二| 国产在线看片免费视频在线观看| 国产传媒av在线| 欧美成人基地| 亚洲激情黄色| 综合五月婷婷| 日韩av网站在线观看| 国产日韩三级| 你懂的国产精品永久在线| 麻豆国产精品视频| 日本а中文在线天堂| 久久中文亚洲字幕| 亚洲欧洲一区二区天堂久久| 一区二区91| 国产精品videossex| 欧美丰满日韩| 91精品观看| 日韩国产一二三区| 国产精品手机在线播放| 狠狠躁少妇一区二区三区| 成人av二区| 日韩有吗在线观看| 久久精品日韩欧美| 国产99精品一区| 国产色综合网| 国产乱子精品一区二区在线观看 | 亚洲图片久久| 国产精品xvideos88| 日韩免费福利视频| 久久国产精品毛片| 国产精品久久乐| 日韩三区免费| 日韩精品一区第一页| 欧美三区不卡| 国产aa精品| 国产精品丝袜xxxxxxx| 久久激情av| 久久久久久自在自线| 伊人久久亚洲热| 国产午夜久久av| 日韩在线短视频| 综合一区av| 97精品国产福利一区二区三区| 婷婷久久一区| 国产日韩欧美一区二区三区在线观看| 亚洲黄色免费av| 日本欧洲一区二区| 精品国产不卡一区二区| 亚洲大全视频| 日韩av午夜在线观看| 波多野结衣久久精品| 亚洲资源在线| 日韩精品dvd| 日欧美一区二区| 天堂√8在线中文| 日韩精品导航| 亚洲午夜久久久久久尤物 | 精品国产欧美日韩一区二区三区| 久久伦理在线| 国产乱子精品一区二区在线观看| 久久高清免费| 国产精品成人**免费视频| 久久国产成人午夜av影院宅| 国产探花在线精品| 欧美特黄一区| 国产成人精品亚洲线观看 | 另类av一区二区| 成人影视亚洲图片在线| 中文字幕日本一区二区| 少妇久久久久| 免费视频一区二区三区在线观看| 亚洲一区二区网站| 中文在线资源| 国产精品久久久久9999高清|