AOP实现(三)——Spring 2.0中Pointcut的定义
在Spring 2.0中,Pointcut的定义包括两个部分:Pointcut表示式(expression)和Pointcut签名(signature)。让我们先看看execution表示式的格式:
java 代码
execution(modifier-pattern? ret-type-pattern declaring-type-pattern? name-pattern(param-pattern) throws-pattern?)
//Pointcut表示式 @Pointcut("execution(* com.savage.aop.MessageSender.*(..))") //Point签名 private void log(){}
@Before("og()")
@Before("execution(* com.savage.aop.MessageSender.*(..))")
@Pointcut("execution(* com.savage.aop.MessageSender.*(..))") private void logSender(){} @Pointcut("execution(* com.savage.aop.MessageReceiver.*(..))") private void logReceiver(){} @Pointcut("logSender() || logReceiver()") private void logMessage(){}
package com.savage.aop; import org.aspectj.lang.annotation.*; public class Pointcuts { @Pointcut("execution(* *Message(..))") public void logMessage(){} @Pointcut("execution(* *Attachment(..))") public void logAttachment(){} @Pointcut("execution(* *Service.*(..))") public void auth(){} }
package com.savage.aop; import org.aspectj.lang.JoinPoint; import org.aspectj.lang.annotation.*; @Aspect public class LogBeforeAdvice { @Before("com.sagage.aop.Pointcuts.logMessage()") public void before(JoinPoint joinPoint) { System.out.println("Logging before " + joinPoint.getSignature().getName()); } }
<aop:config> <aop:pointcut id="log" expression="execution(* com.savage.simplespring.bean.MessageSender.*(..))"/> <aop:aspect id="logging" ref="logBeforeAdvice"> <aop:before pointcut-ref="log" method="before"/> <aop:after-returning pointcut-ref="log" method="afterReturning"/> </aop:aspect> </aop:config>