當前位置:
首頁 >
指定切面的优先级
發布時間:2024/4/13
28
豆豆
指定切面的優先級
在同一個連接點上應用不止一個切面時, 除非明確指定, 否則它們的優先級是不確定的.
切面的優先級可以通過實現 Ordered 接口或利用 @Order 注解指定.
實現 Ordered 接口, getOrder() 方法的返回值越小, 優先級越高.
若使用 @Order 注解, 序號出現在注解中
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 { /*** 前置通知: 在方法執行之前執行.* JoinPoint:連接點對象 包含了連接點相關的信息:方法名 方法的參數等....*///@Before("execution(public int com.learn.spring.aspectJ.ArithmeticCalculator.add(int,int))")//@Before("execution(public int com.learn.spring.aspectJ.ArithmeticCalculator.*(int,int))")//任意修飾符任意返回值 com.learn.spring.aspectJ包下的任意類的任意方法 任意參數//@Before("execution(* com.learn.spring.aspectJ.*.*(..))")@Before("suibian()")public void beforeMethod(JoinPoint joinPoint){//獲取方法名:String methodName = joinPoint.getSignature().getName();//獲取參數Object [] args = joinPoint.getArgs();System.out.println("The method "+methodName+" begins with "+ Arrays.asList(args));}} package com.learn.spring.aspectJ;import java.util.Arrays;import org.aspectj.lang.JoinPoint; import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Before; import org.springframework.core.annotation.Order; import org.springframework.stereotype.Component;@Component @Aspect @Order(2) public class ValidatorAspect {//@Before("execution(* com.learn.spring.aspectJ.*.*(..))")@Before("com.learn.spring.aspectJ.LoggingAspect.suibian()")public void beforeMethod(JoinPoint joinPoint){String methodName = joinPoint.getSignature().getName();Object [] args = joinPoint.getArgs();System.out.println("Validator===>The method "+methodName+" begins with" + Arrays.asList(args));} }?
總結