后置通知
后置通知?
后置通知是在連接點完成之后執行的, 即連接點返回結果或者拋出異常的時候, 下面的后置通知記錄了方法的終止. 一個切面可以包括一個或者多個通知. package com.learn.spring.aspectJ;import java.util.Arrays;import org.aspectj.lang.JoinPoint; import org.aspectj.lang.ProceedingJoinPoint; import org.aspectj.lang.annotation.After; import org.aspectj.lang.annotation.AfterReturning; import org.aspectj.lang.annotation.AfterThrowing; import org.aspectj.lang.annotation.Around; import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Before; import org.aspectj.lang.annotation.Pointcut; import org.springframework.core.annotation.Order; import org.springframework.stereotype.Component;/*** 日志切面*/ @Component //標識為組件 @Aspect //標識為切面 @Order(3) //指定切面的優先級. 值越小,優先級越高. 標注@Order的切面比不標注@Order切面的優先級高 public class LoggingAspect {/*** 后置通知: 在方法執行后執行,不管方法有沒有拋出異常.* 后置通知訪問不到方法的返回值*///@After("execution(* com.learn.spring.aspectJ.*.*(..))")public void afterMethod(JoinPoint joinPoint){//獲取方法名:String methodName = joinPoint.getSignature().getName();System.out.println("The methods "+methodName+" ends .");}?
總結