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

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

Spring AOP 實現自定義注解的示例

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

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

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. 這是一個切面類 */@Aspect@Component@Slf4jpublic class MyLogAspect { /** * 2. PointCut表示這是一個切點,@annotation表示這個切點切到一個注解上,后面帶該注解的全類名 * 切面最主要的就是切點,所有的故事都圍繞切點發(fā)生 * logPointCut()代表切點名稱 */ @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(); // 獲取參數String params = StringUtils.join(joinPoint.getArgs(), ';'); Principal currentUser = AuthorizeUtil.getCurrentUser();log.info('當前登陸用戶:' + (null == currentUser ? '' : currentUser.toString()) + ',進入 [ ' + methodFullPathName + ' ] 方法, 方法的描述:' + myLog.desc() + ',參數為:' + params); // 繼續(xù)執(zhí)行方法long startTime = System.currentTimeMillis();Object result = null;try { result = joinPoint.proceed();} catch (Throwable e) { log.error('切面執(zhí)行報錯,參數:' + params, e);}long elapsed = System.currentTimeMillis() - startTime; log.info('[ ' + methodFullPathName + ' ] 方法執(zhí)行結束,返回值為:' + (null == result ? '' : result.toString()) + ',用時:' + elapsed); return result; }}

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

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

以上就是Spring AOP 實現自定義注解的示例的詳細內容,更多關于Spring AOP 實現自定義注解的資料請關注好吧啦網其它相關文章!

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品99久久久久久董美香| 欧美/亚洲一区| 欧美日韩亚洲一区二区三区在线| 最近高清中文在线字幕在线观看1| 久久久久美女| 尤物在线精品| 国产精品草草| 亚洲在线观看| 日韩欧美一区二区三区免费观看| 欧美成a人片免费观看久久五月天| 亚洲最新av| 国产精品一站二站| 欧美1级日本1级| 久草免费在线视频| 亚洲一级大片| 日本亚洲欧美天堂免费| 香蕉精品视频在线观看| 久久久国产精品网站| 国产一区二区三区四区二区| 国产精品videossex| 人人精品久久| 色综合视频一区二区三区日韩 | 欧美成人基地| 国产精品第十页| 欧美影院精品| 精品日本视频| 黄色av日韩| 色综合视频一区二区三区日韩| 久久一区二区三区喷水| 亚洲啊v在线免费视频| 国产欧美日韩在线一区二区| 亚洲人www| 91精品美女| 亚洲成人不卡| 欧美一级精品| 亚洲欧美日韩国产一区二区| 91p九色成人| 少妇精品久久久一区二区三区| 亚洲国产日韩欧美在线| 成人污污视频| 综合国产视频| 精品久久精品| 欧洲毛片在线视频免费观看| 在线亚洲一区| 美女视频黄久久| 亚洲一区二区三区四区五区午夜| 美女精品在线观看| 蜜臀精品一区二区三区在线观看 | 欧美午夜三级| 日韩精品视频一区二区三区| 国产高清亚洲| 亚洲综合电影| 亚洲永久字幕| 国产精品一级| 一区二区三区国产在线| 久久av导航| 偷拍亚洲精品| 精品久久久亚洲| 中文无码日韩欧| 国产精品magnet| 久久精品成人| 欧美日韩国产综合网| 国产精品九九| 久久在线免费| 精品一区二区三区视频在线播放 | 国产精品一区二区精品| 久久亚洲黄色| 亚洲天堂日韩在线| 成人亚洲欧美| 国产va在线视频| 欧美色综合网| 久久黄色影视| **爰片久久毛片| 亚洲人成在线影院| 欧美aa在线视频| 日韩高清一区| 久久久国产精品网站| 精品欧美日韩精品| 国产在线观看www| 久久男人天堂| 黑丝一区二区三区| 国产精品美女久久久久久不卡| 成午夜精品一区二区三区软件| 欧美精品高清| 欧美黄色一区二区| 久久久亚洲一区| 日韩综合一区二区| 免费看av不卡| 丝瓜av网站精品一区二区| 青草久久视频| 9国产精品视频| 欧美激情视频一区二区三区免费| 激情欧美一区| 亚洲综合电影| 一级欧美视频| 国产精品精品| 蜜臀精品一区二区三区在线观看| 国产精品极品国产中出| 麻豆成全视频免费观看在线看| 久久午夜精品一区二区| 国产极品久久久久久久久波多结野| 999视频精品| 亚洲另类视频| 午夜电影亚洲| 久久一区欧美| 日本亚洲不卡| 免费av一区| 精品国产日韩欧美精品国产欧美日韩一区二区三区 | 国产精品婷婷| 91中文字幕精品永久在线| 亚洲伊人影院| 99热精品久久| 精品国产乱码| 欧美另类中文字幕| 日韩中文字幕一区二区高清99| 国产手机视频一区二区 | 在线成人动漫av| 丝袜亚洲另类欧美| 欧美日韩国产传媒| 国产精品av久久久久久麻豆网| 日韩久久视频| 欧美在线91| 日韩欧美三区| 一区二区国产精品| 美美哒免费高清在线观看视频一区二区 | 日本aⅴ亚洲精品中文乱码| yellow在线观看网址| 国产伦久视频在线观看| 99在线|亚洲一区二区| 欧美1级日本1级| 成人福利视频| 中文av在线全新| 精品91福利视频| 国产极品一区| 国产一区二区三区自拍| 欧美天堂亚洲电影院在线观看| 91精品综合| 麻豆91精品视频| 精品国产一区二区三区性色av| 国产a久久精品一区二区三区| 亚洲调教视频在线观看| 欧美成人基地| 日韩欧美精品一区| 一区二区三区四区在线看| 天堂网在线观看国产精品| 成人精品中文字幕| 久久伊人亚洲| 97人人精品| 精品一区亚洲| 久久久久九九精品影院| 桃色一区二区| 亚洲精品1区2区| 你懂的国产精品永久在线| 成人黄色av| 婷婷综合网站| 亚洲精品激情| 国产伦精品一区二区三区在线播放| 久久影视三级福利片| 国产精品亲子伦av一区二区三区 | 日韩精品一区二区三区中文在线| 日韩精品午夜视频| 国产suv精品一区| 日韩精品午夜视频| 一区二区小说| 青青青国产精品| 久久久一本精品| 日韩国产91| 日韩黄色大片| 青青草国产成人99久久| 国产拍在线视频| 免费成人性网站| 美女一区网站| 日韩欧美久久| 日韩中文字幕区一区有砖一区| 精品国产不卡| 91精品观看| 国产精品久久久久久av公交车| 亚洲三级视频| 欧美gv在线| 国产麻豆精品| 欧美大黑bbbbbbbbb在线| 精品资源在线| 国产精品毛片久久久| 免费看欧美美女黄的网站| 婷婷成人基地| 亚洲一卡久久| а√天堂8资源中文在线| 91麻豆精品激情在线观看最新| 亚洲精品大全| 久久黄色影院| 日韩欧美一区二区三区在线视频 | 日韩av黄色在线| japanese国产精品| 午夜日韩福利| 久久一级电影| 国产传媒av在线| 极品av在线| 麻豆精品蜜桃| 神马日本精品| 成人自拍av|