AOP实现(三)--spring2.0中pointcut定义

来源:互联网 发布:苹果免费看书软件 编辑:程序博客网 时间:2024/05/19 23:10

关键字: Pointcut的定义

Spring 2.0中,Pointcut的定义包括两个部分:Pointcut表示式(expression)Pointcut签名(signature)。让我们先看看execution表示式的格式:
java 代码
  1. execution(modifier-pattern?
  2.           ret-type-pattern
  3.           declaring-type-pattern?
  4.           name-pattern(param-pattern)
  5.           throws-pattern?)

括号中各个pattern分别表示修饰符匹配(modifier-pattern?)、返回值匹配(ret-type-pattern)、类路径匹配(declaring-type-pattern?)、方法名匹配(name-pattern)、参数匹配((param-pattern))、异常类型匹配(throws-pattern?),其中后面跟着“?”的是可选项。
在各个pattern中可以使用“*”来表示匹配所有。在(param-pattern)中,可以指定具体的参数类型,多个参数间用“,”隔开,各个也可以用“*”来表示匹配任意类型的参数,如(String)表示匹配一个String参数的方法;(*,String)表示匹配有两个参数的方法,第一个参数可以是任意类型,而第二个参数是String类型;可以用(..)表示零个或多个任意参数。
现在来看看几个例子:
1execution(* *(..))
表示匹配所有方法
2execution(public * com. savage.service.UserService.*(..))
表示匹配com.savage.server.UserService中所有的公有方法
3execution(* com.savage.server..*.*(..))
表示匹配com.savage.server包及其子包下的所有方法
除了execution表示式外,还有withinthistargetargsPointcut表示式。一个Pointcut定义由Pointcut表示式和Pointcut签名组成,例如:
java 代码
  1. //Pointcut表示式
  2. @Pointcut("execution(* com.savage.aop.MessageSender.*(..))")
  3. //Point签名
  4. privatevoid log(){}                             然后要使用所定义的Pointcut时,可以指定Pointcut签名,如
    java 代码
    1. @Before("og()")

    上面的定义等同与:
    java 代码
    1. @Before("execution(* com.savage.aop.MessageSender.*(..))")

    Pointcut定义时,还可以使用&||!运算,如:
    java 代码
    1. @Pointcut("execution(* com.savage.aop.MessageSender.*(..))")
    2. privatevoid logSender(){}
    3. @Pointcut("execution(* com.savage.aop.MessageReceiver.*(..))")
    4. privatevoid logReceiver(){}
    5. @Pointcut("logSender() || logReceiver()")
    6. privatevoid logMessage(){}

    这个例子中,logMessage()将匹配任何MessageSenderMessageReceiver中的任何方法。
    还可以将一些公用的Pointcut放到一个类中,以供整个应用程序使用,如:
    java 代码
    1. package com.savage.aop;
    2. import org.aspectj.lang.annotation.*;
    3. publicclass Pointcuts {
    4.    @Pointcut("execution(* *Message(..))")
    5.    publicvoid logMessage(){}
    6.    @Pointcut("execution(* *Attachment(..))")
    7.    publicvoid logAttachment(){}
    8.    @Pointcut("execution(* *Service.*(..))")
    9.    publicvoid auth(){}
    10. }

    在使用这些Pointcut时,指定完整的类名加上Pointcut签名就可以了,如:
    java 代码
    1. package com.savage.aop;
    2. import org.aspectj.lang.JoinPoint;
    3. import org.aspectj.lang.annotation.*;
    4. @Aspect
    5. publicclass LogBeforeAdvice {
    6.    @Before("com.sagage.aop.Pointcuts.logMessage()")
    7.    publicvoid before(JoinPoint joinPoint) {
    8.       System.out.println("Logging before " + joinPoint.getSignature().getName());
    9.    }
    10. }

    当基于XML Sechma实现Advice时,如果Pointcut需要被重用,可以使用<aop:pointcut></aop:pointcut>来声明Pointcut,然后在需要使用这个Pointcut的地方,用pointcut-ref引用就行了,如:
    xml 代码
    1. <aop:config>  
    2.     <aop:pointcutid="log"   
    3.           expression="execution(* com.savage.simplespring.bean.MessageSender.*(..))"/>  
    4.     <aop:aspectid="logging"ref="logBeforeAdvice">  
    5.         <aop:beforepointcut-ref="log"method="before"/>  
    6.         <aop:after-returningpointcut-ref="log"method="afterReturning"/>  
    7.     </aop:aspect>  
    8. </aop:config>  


原创粉丝点击