鍍金池/ 教程/ Java/ Spring AOP自定義注解
Spring AOP基于XML的After Advice
Spring AOP基于XML的Before Advice
Spring AOP基于XML的After Returning Advice
Spring AOP基于注解的切入點
Spring AOP基于XML的After Throwing Advice
Spring AOP實現(xiàn)
Spring AOP基于注解的Around通知
Spring AOP環(huán)境安裝設(shè)置
Spring AOP自定義注解
Spring AOP代理
Spring AOP基于XML的切入點
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自定義注解

根據(jù)切入點表達式可能會將它們應(yīng)用到其他不需要通知的其他bean。 例如,考慮以下表達式:

execution(* com.yiibai.*.getAge(..))

如果一個新的spring bean添加了getAge()方法,并且通知將開始應(yīng)用到它,盡管它可能不需要應(yīng)用通知。要實現(xiàn)不需要它,我們可以創(chuàng)建一個自定義注解并注解要應(yīng)用到通知的方法。

@Before("@annotation(com.yiibai.Loggable)")

要了解上面提到的關(guān)于@BeforeAdvice的概念,現(xiàn)在我們來寫一個實現(xiàn)@BeforeAdvice的例子。打開并使用Eclipse IDE,并按照以下步驟創(chuàng)建一個Spring應(yīng)用程序:

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

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

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

package com.yiibai;

import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;

@Aspect
public class Logging {

   /** 
    * This is the method which I would like to execute
    * before a selected method execution.
    */
   @Before("@annotation(com.yiibai.Loggable)")
   public void beforeAdvice(){
      System.out.println("Going to setup student profile.");
   }  
}

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

package com.yiibai;

public @interface Loggable {

}

以下是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 );
      return age;
   }

   public void setName(String name) {
      this.name = name;
   }
   @Loggable
   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:aspectj-autoproxy/>

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

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

</beans>

運行項目

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

Going to setup student profile.
Name : minsu
Age : 26