一个简单的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   回复   更多评论
相关文章
相关标签/搜索