鍍金池/ 教程/ Java/ Spring AOP基于XML的After Returning Advice
Spring AOP基于XML的After Advice
Spring AOP基于XML的Before Advice
Spring AOP基于XML的After Returning Advice
Spring AOP基于注解的切入點(diǎn)
Spring AOP基于XML的After Throwing Advice
Spring AOP實(shí)現(xiàn)
Spring AOP基于注解的Around通知
Spring AOP環(huán)境安裝設(shè)置
Spring AOP自定義注解
Spring AOP代理
Spring AOP基于XML的切入點(diǎn)
Spring AOP基于XML的Around Advice
Spring AOP通知類型
Spring AOP基于XML的應(yīng)用程序
Spring AOP基于注解的After Advice
Spring AOP基于注解的Before Advice
Spring AOP基于注解的AfterThrowing
Spring AOP教程
Spring AOP基于注解的After Returning Advice
Spring AOP核心概念
Spring AOP基于注解的應(yīng)用

Spring AOP基于XML的After Returning Advice

之后(After)是一種通知類型,只有在方法成功完成后,確保方法執(zhí)行后才能運(yùn)行通知。 以下是之后通知(after advice)的語法:

語法

  <aop:config>
   <aop:aspect id="log" ref="logging">
      <aop:pointcut id="pointcut-id" expression="execution( expression )"/>    
      <aop:after-returning pointcut-ref="pointcut-id" returning="retVal" method="methodName"/>
   </aop:aspect>
   </aop:config>

在上面配置中,

  • pointcut-id - 切入點(diǎn)的id。
  • methodName - 在調(diào)用函數(shù)之前調(diào)用的函數(shù)的方法名稱。

要了解上述與之后返回通知(After Returning Advice)相關(guān)的概念,寫一個在實(shí)現(xiàn)之后返回通知(After Returning Advice)的示例。為了簡單,可直接復(fù)制之前上一篇文章中的例子,打開并使用Eclipse IDE,并按照以下步驟創(chuàng)建一個Spring應(yīng)用程序:

  1. 更新在Spring AOP應(yīng)用實(shí)例中創(chuàng)建過的Student項目。
  2. 更新bean配置并運(yùn)行應(yīng)用程序,如下所述。

整個項目的目錄結(jié)構(gòu)如下所示 -

下面是Logging.java文件的內(nèi)容。 這實(shí)際上是一個Aspect模塊的樣本,它定義了在各個點(diǎn)被調(diào)用的方法。

package com.yiibai;

public class Logging {

    /** 
    * This is the method which I would like to execute
    * when any method returns.
    */
   public void afterReturningAdvice(Object retVal){
      System.out.println("[afterReturningAdvice] Returning: " + retVal.toString());
   }
}

以下是Student.java文件的內(nèi)容:

package com.yiibai;

public class Student {
   private Integer age;
   private String name;

   public void setAge(Integer age) {
      this.age = age;
   }
   public Integer getAge() {
      System.out.println("Age : " + age );
      System.out.println("Exception raised");
      throw new IllegalArgumentException();
      return age;
   }

   public void setName(String name) {
      this.name = name;
   }
   public String getName() {
      System.out.println("Name : " + name );
      return name;
   }

   public void printThrowException(){
       System.out.println("Exception raised");
       throw new IllegalArgumentException();
   }
}

以下是MainApp.java文件的內(nèi)容:

package com.yiibai;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class MainApp {
   public static void main(String[] args) {
      ApplicationContext context = 
             new ClassPathXmlApplicationContext("Beans.xml");

      Student student = (Student) context.getBean("student");

      student.getName();
      student.getAge();     
   }
}

以下是配置文件Beans.xml文件的內(nèi)容:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xmlns:aop="http://www.springframework.org/schema/aop"
    xsi:schemaLocation="http://www.springframework.org/schema/beans
    http://www.springframework.org/schema/beans/spring-beans-3.0.xsd 
    http://www.springframework.org/schema/aop 
    http://www.springframework.org/schema/aop/spring-aop-3.0.xsd ">

   <aop:config>
      <aop:aspect id="log" ref="logging">
         <aop:pointcut id="selectAll" 
         expression="execution(* com.yiibai.*.*(..))"/>
         <aop:after-returning pointcut-ref="selectAll" method="afterReturningAdvice" returning="retVal"/>         
      </aop:aspect>
   </aop:config>

   <!-- Definition for student bean -->
   <bean id="student" class="com.yiibai.Student">
      <property name="name"  value="Zara" />
      <property name="age"  value="11"/>      
   </bean>

   <!-- Definition for logging aspect -->
   <bean id="logging" class="com.yiibai.Logging"/> 

</beans>

運(yùn)行項目

完成創(chuàng)建源代碼和配置文件后,運(yùn)行應(yīng)用程序。右鍵單擊應(yīng)用程序中的MainApp.java,并使用運(yùn)行方式作為Java應(yīng)用程序命令。 如果您的應(yīng)用程序一切正常,這將打印以下消息:

Name : Maxsu
[afterReturningAdvice] Returning: Maxsu
Age : 26
[afterReturningAdvice] Returning: 26