一個簡單的Spring的AOP例子

      通過這段日子的學習和使用Spring,慢慢地體會到Spring的優妙之處,正在深刻地吸取Spring的精華,呵呵。如今寫的這個只是個簡單AOP例子,包括前置通知,後置通知,環繞通知,和目標對象。寫這個例子的主要目標只是想讓想學AOP的能更快地入門,瞭解一下如何去配置AOP裏面的東東。

目標對象的接口:IStudent.java html

 1    /** 
 2  * 
 3   */ 

 4    package  com.dragon.study;
 5   
 6    /** 
 7  *  @author   dragon
 8  *
 9   */ 

10    public    interface  IStudent   {
11     
12      public   void  addStudent(String name);
13 

14 


目標類:StudentImpl.java java

 1    /** 
 2  * 
 3   */ 

 4    package  com.dragon.study.Impl;
 5   
 6    import  com.dragon.study.IStudent;
 7   
 8    /** 
 9  *  @author   dragon
10  *
11   */ 

12    public    class  StudentImpl   implements  IStudent  {
13  
14        public   void  addStudent(String name) {
15          System.out.println( " 歡迎  " + name + "  你加入Spring家庭! " );
16      } 

17 

18 



前置通知:BeforeAdvice.java spring

 1    /** 
 2  * 
 3   */ 

 4    package  com.dragon.Advice;
 5   
 6    import  java.lang.reflect.Method;
 7   
 8    import  org.springframework.aop.MethodBeforeAdvice;
 9   
10    /** 
11  *  @author   dragon
12  *
13   */ 

14    public    class  BeforeAdvice   implements  MethodBeforeAdvice  {
15  
16        public   void  before(Method method,Object[] args, Object target)
17                  throws  Throwable {
18           
19           System.out.println( " 這是BeforeAdvice類的before方法. " );
20           
21       } 

22 

23 

後置通知:AfterAdvice.java
 1 /**
 2 * 
 3 */

 4 package com.dragon.Advice;
 5
 6 import java.lang.reflect.Method;
 7
 8 import org.springframework.aop.AfterReturningAdvice;
 9
10 /**
11 * @author  dragon
12 *
13 */

14 public  class AfterAdvice  implements AfterReturningAdvice {
15    
16    public void afterReturning(Object returnValue ,Method method,
17                   Object[] args,Object target) throws Throwable{
18        System.out.println("這是AfterAdvice類的afterReturning方法.");
19    }

20      
21
22}

23


環繞通知:CompareInterceptor.java
app

 1 /**
 2 * 
 3 */

 4 package com.dragon.Advice;
 5
 6 import org.aopalliance.intercept.MethodInterceptor;
 7 import org.aopalliance.intercept.MethodInvocation;
 8
 9
10 /**
11 * @author  dragon
12 *
13 */

14 public  class CompareInterceptor  implements MethodInterceptor {
15
16      public Object invoke(MethodInvocation invocation) throws Throwable{
17          Object result = null;
18         String stu_name = invocation.getArguments()[0].toString();
19         if ( stu_name.equals("dragon")){
20             //若是學生是dragon時,執行目標方法,
21              result= invocation.proceed();
22              
23         }
 else{
24             System.out.println("此學生是"+stu_name+"而不是dragon,不批准其加入.");
25         }

26        
27          return result;
28      }

29}

30

配置文件applicationContext.xml
 1 <? xml version="1.0" encoding="UTF-8" ?>
 2 <! DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd" >
 3
 4 < beans >
 5
 6 < bean  id ="beforeAdvice"  class ="com.dragon.Advice.BeforeAdvice" ></ bean >
 7 < bean  id ="afterAdvice"  class ="com.dragon.Advice.AfterAdvice" ></ bean >
 8 < bean  id ="compareInterceptor"  class ="com.dragon.Advice.CompareInterceptor" ></ bean >
 9 < bean  id ="studenttarget"  class ="com.dragon.study.Impl.StudentImpl" ></ bean >
10
11 < bean  id ="student"  class ="org.springframework.aop.framework.ProxyFactoryBean" >
12    < property  name ="proxyInterfaces" >
13      < value >com.dragon.study.IStudent </ value >
14    </ property >
15    < property  name ="interceptorNames" >
16      < list >
17       < value >beforeAdvice </ value >
18       < value >afterAdvice </ value >
19      < value >compareInterceptor </ value >  
20      </ list >
21    </ property >
22    < property  name ="target" >
23      < ref  bean ="studenttarget" />
24    </ property >
25
26 </ bean >
27
28
29
30
31 </ beans >


  如今開始寫測試類,Test.java
 1 /**
 2 * 
 3 */

 4 package com;
 5
 6 import org.springframework.context.ApplicationContext;
 7 import org.springframework.context.support.FileSystemXmlApplicationContext;
 8
 9 import com.dragon.study.IStudent;
10
11 /**
12 * @author  dragon
13 *
14 */

15 public  class Test  {
16
17    /**
18     * @param args
19     */

20    public static void main(String[] args) {
21        // TODO Auto-generated method stub
22      ApplicationContext ctx = 
23          new FileSystemXmlApplicationContext("/com/dragon/applicationContext.xml");
24      
25      IStudent person = (IStudent)ctx.getBean("student");
26      person.addStudent("dragon");
27      
28//      person.addStudent("javadragon");
29    }

30
31}

32
posted on 2006-12-03 03:29  javadragon 閱讀(754)  評論(8)   編輯   收藏

評論:
#  re: 一個簡單的Spring的AOP例子 2007-02-22 11:41 |  freesky_zh
這個類public class BeforeAdvice implements MethodBeforeAdvice 
好像有點問題,在Eclipse中會報錯。   回覆   更多評論
  
#  re: 一個簡單的Spring的AOP例子 2007-02-28 20:34 |  javadragon
我又試了次,沒有錯呀,若是你的還出現錯誤, 
請你把整個工程發給我試下 
郵箱:newlong@126.com   回覆   更多評論
  
#  re: 一個簡單的Spring的AOP例子 2007-03-10 10:54 |  weichenggao
不錯,好例子,不過運行該程序,還須要加入commons-logging.jar 
請你們注意!   回覆   更多評論
  
#  re: 一個簡單的Spring的AOP例子 2007-03-24 00:31 |  鳥不生蛋蛋的地方
Nice,u've done a good job, keep practice, keep thinking, then move forward. God's watching u ,ahahaha~   回覆   更多評論
  
#  re: 一個簡單的Spring的AOP例子 2007-03-26 20:25 |  javadragon
Thank you! if you don't guided i to how to program,my program capability can't improve. you give me a importnat thing--thinking.thanks again ! i will become stronger. Sorry for my english.haha   回覆   更多評論
  
#  re: 一個簡單的Spring的AOP例子 2007-10-11 13:38 |  pcz
AfterAdvice 

不能在方法執行後 在執行啊!   回覆   更多評論
  
#  re: 一個簡單的Spring的AOP例子 2007-10-12 22:06 |  javadragon
有什麼問題?   回覆   更多評論
  
#  re: 一個簡單的Spring的AOP例子  2007-11-12 18:16 |  landon
good job   回覆   更多評論
相關文章
相關標籤/搜索