spring boot中使用aop

1刃泡、在pom文件中添加aop的依賴


2巧娱、使用示例參考如下

/**

*@authorfangzy

*@since2017/8/14.

*類級(jí)注解:

*@Aspect聲明這是一個(gè)切面對(duì)象

*方法級(jí)注解:

*@Pointcut聲明一個(gè)切點(diǎn)規(guī)則

*@Before方法執(zhí)行之前,執(zhí)行通知烘贴。

*@After方法執(zhí)行之后禁添,不考慮其結(jié)果,執(zhí)行通知桨踪。

*@AfterReturning方法執(zhí)行之后老翘,只有在方法成功完成時(shí),才能執(zhí)行通知

*@AfterThrowing方法執(zhí)行之后,只有在方法退出拋出異常時(shí)铺峭,才能執(zhí)行通知

*@Around在方法調(diào)用之前和之后墓怀,執(zhí)行通知 等價(jià)于上面四個(gè)相加

*/

@Component

@Aspect

public classMyAdvice {

Loggerlogger= LoggerFactory.getLogger(MyAdvice.class);

// expression配置切點(diǎn)的表達(dá)式,切到哪

@Pointcut("execution(* com.example.springboot.*Service.*(..))")

private voidbusinessService() {

}

//在一個(gè)方法執(zhí)行之前卫键,執(zhí)行通知傀履。

@Before("businessService()")

public voiddoBeforeTask(JoinPoint joinPoint) {

logger.info("doBeforeTask.");

ServletRequestAttributes requestAttributes = (ServletRequestAttributes)RequestContextHolder.getRequestAttributes();

HttpServletRequest request = requestAttributes.getRequest();

logger.info("請(qǐng)求的ip:{}",request.getRemoteAddr());

logger.info("請(qǐng)求的uri:{}",request.getRequestURI());

logger.info("請(qǐng)求的method:{}",request.getMethod());

logger.info("請(qǐng)求的類方法:{}.{}",joinPoint.getSignature().getDeclaringTypeName(),joinPoint.getSignature().getName());

logger.info("請(qǐng)求參數(shù){}",joinPoint.getArgs());

}

//在一個(gè)方法執(zhí)行之后,不考慮其結(jié)果莉炉,執(zhí)行通知钓账。

@After("businessService()")

public voiddoAfterTask() {

logger.info("doAfterTask.");

}

//在一個(gè)方法執(zhí)行之后,只有在方法成功完成時(shí)絮宁,才能執(zhí)行通知梆暮。

@AfterReturning(pointcut="businessService()",returning="retVal")

public voiddoAfterReturnningTask(JoinPoint joinPoint,Object retVal) {

String methodName = joinPoint.getSignature().getName();

logger.info("doAfterReturnningTask {} return with {}",methodName,retVal);

}

//在一個(gè)方法執(zhí)行之后,只有在方法退出拋出異常時(shí)绍昂,才能執(zhí)行通知

@AfterThrowing(pointcut="businessService()",throwing="ex")

public voiddoAfterThrowingTask(JoinPoint joinPoint,Exception ex) {

String methodName = joinPoint.getSignature().getName();

logger.info("doAfterThrowingTask {} occurs exception: {} ",methodName,ex);

}

//在建議方法調(diào)用之前和之后惕蹄,執(zhí)行通知。

@Around("businessService()")

publicObjectdoAroundTask(ProceedingJoinPoint jpoint) {

Object result =null;

String methodName = jpoint.getSignature().getName();

//執(zhí)行目標(biāo)方法

try{

//前置通知

logger.info("The method {} begins with {}",methodName,Arrays.asList(jpoint.getArgs()));

result = jpoint.proceed();

//返回通知

logger.info("The method {} ends with {} ",methodName,Arrays.asList(jpoint.getArgs()));

}catch(Throwable e) {

//異常通知

logger.info("The method {} occurs expection {} ",methodName,e);

throw newRuntimeException(e);

}

//后置通知

logger.info("The method {} ends",methodName);

returnresult;

}

}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末治专,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子遭顶,更是在濱河造成了極大的恐慌张峰,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,496評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件棒旗,死亡現(xiàn)場(chǎng)離奇詭異喘批,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)铣揉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門饶深,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人逛拱,你說我怎么就攤上這事敌厘。” “怎么了朽合?”我有些...
    開封第一講書人閱讀 162,632評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵俱两,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我曹步,道長(zhǎng)宪彩,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,180評(píng)論 1 292
  • 正文 為了忘掉前任讲婚,我火速辦了婚禮尿孔,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己活合,他們只是感情好雏婶,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,198評(píng)論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著芜辕,像睡著了一般尚骄。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上侵续,一...
    開封第一講書人閱讀 51,165評(píng)論 1 299
  • 那天倔丈,我揣著相機(jī)與錄音,去河邊找鬼状蜗。 笑死需五,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的轧坎。 我是一名探鬼主播宏邮,決...
    沈念sama閱讀 40,052評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼缸血!你這毒婦竟也來了蜜氨?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,910評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤捎泻,失蹤者是張志新(化名)和其女友劉穎飒炎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體笆豁,經(jīng)...
    沈念sama閱讀 45,324評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡郎汪,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,542評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了闯狱。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片煞赢。...
    茶點(diǎn)故事閱讀 39,711評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖哄孤,靈堂內(nèi)的尸體忽然破棺而出照筑,到底是詐尸還是另有隱情,我是刑警寧澤瘦陈,帶...
    沈念sama閱讀 35,424評(píng)論 5 343
  • 正文 年R本政府宣布朦肘,位于F島的核電站,受9級(jí)特大地震影響双饥,放射性物質(zhì)發(fā)生泄漏媒抠。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,017評(píng)論 3 326
  • 文/蒙蒙 一咏花、第九天 我趴在偏房一處隱蔽的房頂上張望趴生。 院中可真熱鬧阀趴,春花似錦、人聲如沸苍匆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽浸踩。三九已至叔汁,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間检碗,已是汗流浹背据块。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評(píng)論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留折剃,地道東北人另假。 一個(gè)月前我還...
    沈念sama閱讀 47,722評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像怕犁,于是被迫代替她去往敵國和親边篮。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,611評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容