spring 2.0 aop配置


 spring2.0 ,aop        :
        
1.     aop xml  
2.  @AspectJ   

          :
    aspect, xml      :

<aop:config>

  <aop:aspect id="myAspect" ref="aBean">

    ...

  </aop:aspect>

</aop:config>



<bean id="aBean" class="...">

  ...

</bean>



  pointcut


<aop:config>

  <aop:pointcut id="businessService" 

        expression="execution(* com.xyz.myapp.service.*.*(..))"/>

</aop:config>


  advice


Before advice:

<aop:aspect id="beforeExample" ref="aBean">

    <aop:before 

      pointcut-ref="dataAccessOperation" 

      method="doAccessCheck"/>

</aop:aspect>

After returning advice:

<aop:aspect id="afterReturningExample" ref="aBean">

 

    <aop:after-returning 

      pointcut-ref="dataAccessOperation" 

      method="doAccessCheck"/>

          

    ...

    

</aop:aspect>

        

<aop:aspect id="afterReturningExample" ref="aBean">

 

    <aop:after-returning 

      pointcut-ref="dataAccessOperation"

      returning="retVal" 

      method="doAccessCheck"/>

          

    ...

    

</aop:aspect>

 

After throwing advice:

<aop:aspect id="afterThrowingExample" ref="aBean">

 

    <aop:after-throwing

      pointcut-ref="dataAccessOperation" 

      method="doRecoveryActions"/>

          

    ...

    

</aop:aspect>

    throwing

<aop:aspect id="afterThrowingExample" ref="aBean">

 

    <aop:after-throwing 

      pointcut-ref="dataAccessOperation"

      throwing="dataAccessEx"

      method="doRecoveryActions"/>

          

    ...

    

</aop:aspect>

After (finally) advice:

<aop:aspect id="afterFinallyExample" ref="aBean">

 

    <aop:after

      pointcut-ref="dataAccessOperation" 

      method="doReleaseLock"/>

          

    ...

    

</aop:aspect>

Around advice:

<aop:aspect id="aroundExample" ref="aBean">

 

    <aop:around

      pointcut-ref="businessService" 

      method="doBasicProfiling"/>

          

    ...

    

</aop:aspect>

Advice parameters:

<aop:before

  pointcut="Pointcuts.anyPublicMethod() and @annotation(auditable)"

  method="audit"

  arg-names="auditable"/>



      (Introductions):


<aop:aspect id="usageTrackerAspect" ref="usageTracking">

  <aop:declare-parents

      types-matching="com.xzy.myapp.service.*+",

      implement-interface="UsageTracked"
      default-impl=" service.tracking.DefaultUsageTracked"/>

  <aop:before

    pointcut="com.xyz.myapp.SystemArchitecture.businessService()

              and this(usageTracked)"

    method="recordUsage"/>

</aop:aspect>


           xml  aop  ,          @AspectJ   。
   @AspectJ     ,
       :
 xml   

<aop:aspectj-autoproxy/>


  
 xml   
<bean class="org.springframework.aop.aspectj.annotation.AnnotationAwareAspectJAutoProxyCreator" />

   aspect

<bean id="myAspect" class="org.xyz.NotVeryUsefulAspect"> 

   <!-- configure properties of aspect here as normal --> 

</bean> 

  

package org.xyz; 

import org.aspectj.lang.annotation.Aspect; 

  

@Aspect 

public class NotVeryUsefulAspect { 

  

}

   pointcut


@Pointcut("execution(* transfer(..))") 

public void transfer() {}



   advice


Before advice: 

@Before("com.xyz.myapp.SystemArchitecture.dataAccessOperation()") 

  public void doAccessCheck() { 

    // ... 

  } 

After returning advice: 

@AfterReturning("com.xyz.myapp.SystemArchitecture.dataAccessOperation()") 

  public void doAccessCheck() { 

    // ... 

  } 

   

@AfterReturning(
pointcut="com.xyz.myapp.SystemArchitecture.dataAccessOperation()",
returning="retVal") 

public void doAccessCheck(Object retVal) { 

    // ... 

  } 

After throwing advice: 

@AfterThrowing("SystemArchitecture.dataAccessOperation()") 

  public void doRecoveryActions() { 

    // ... 

  } 

   

@AfterThrowing( 

    pointcut=" SystemArchitecture.dataAccessOperation()", 

    throwing="ex") 

  public void doRecoveryActions(DataAccessException ex) { 

    // ... 

  } 

After (finally) advice: 

@After("com.xyz.myapp.SystemArchitecture.dataAccessOperation()") 

  public void doReleaseLock() { 

    // ... 

  } 

Around advice: 

@Around("com.xyz.myapp.SystemArchitecture.businessService()") 

  public Object doBasicProfiling( ProceedingJoinPoint pjp) throws Throwable { 

    // start stopwatch 

    Object retVal = pjp.proceed(); 

    // stop stopwatch 

    return retVal; 

  } 

Advice parameters: 

@Before("com.xyz.myapp.SystemArchitecture.dataAccessOperation() &&" + "args(account,..)" ) 

public void validateAccount(Account account) { 

  // ... 

} 

      : 

@Before( 

   value="com.xyz.lib.Pointcuts.anyPublicMethod() && " + 

         "@annotation(auditable)", 

   argNames="auditable" ) 

public void audit(Auditable auditable) { 

  AuditCode code = auditable.value(); 

  // ... 

}  

Advice   : 

              

    Advice ,     Ordered   ,   



Introductions 


         

@Aspect 

public class UsageTracking { 

  

  @DeclareParents(value="com.xzy.myapp.service.*+", 

                  defaultImpl=DefaultUsageTracked.class) 

  public static UsageTracked mixin; 

  

  @Before("com.xyz.myapp.SystemArchitecture.businessService() &&" + 

          "this(usageTracked)") 

  public void recordUsage(UsageTracked usageTracked) { 

    usageTracked.incrementUseCount(); 

  } 

  

}