随笔-10  评论-47  文章-1  trackbacks-0

      经过这段日子的学习和使用Spring,慢慢地体会到Spring的优妙之处,正在深入地吸收Spring的精华,呵呵。现在写的这个只是个简单AOP例子,包括前置通知,后置通知,环绕通知,和目标对象。写这个例子的主要目标只是想让想学AOP的能更快地入门,了解一下如何去配置AOP里面的东东。
目标对象的接口:IStudent.java

 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

 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

 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 */

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

14public 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

 1/**
 2 * 
 3 */

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

14public 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 */

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

15public 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 阅读(15779) 评论(40)  编辑  收藏

评论:
# 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  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2008-04-16 20:42 | 00?
好不错,可以运行,,太需要了,谢谢了,,  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2008-04-20 23:01 | huangzongbai
我按照你的方法去做了,可是Advice不能调用~`,很是郁闷.  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2008-07-14 16:59 | zuoshaobiao
不错 不错 终于弄出来了。谢谢了、  回复  更多评论
  
# re: 一个简单的Spring的AOP例子[未登录] 2008-07-30 20:36 | Rain
虽然将Aop这个例子写的不错!能很好的将要经常使用的代码变成一个“方面”
但是注释要加强!  回复  更多评论
  
# re: 一个简单的Spring的AOP例子[未登录] 2008-07-30 20:52 | Rain
在Spring Appactiocontext.xml配置文件;你定义的前置,后置;环绕等通知在配置文件中实现了代理(org.springframework.aop.framework.ProxyFactoryBean)
以此将通知放入到了原Bean中;这样才能使原Bean中方法调用时自动执行通知
这是其一》
<property name="proxyInterfaces">
<property name="interceptorNames">
<property name="target">
这三个属性是一定要配置的
第一是被代理的接口(IStudent)
第二是通知列表(前置,后置;环绕)上面定义的三个类
第三是被代理的原Bean(StudentImpl )

  回复  更多评论
  
# re: 一个简单的Spring的AOP例子[未登录] 2008-08-01 15:08 |
好不错,可以运行,,太需要了,谢谢了,请你把整个工程发给我试下
邮箱:2008-sina@163.com   回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2008-08-27 14:14 | zackey
@freesky_zh
因为没有导入spring.jar  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2008-09-11 10:49 | 啊正
不错啊~~~谢谢LZ分享!!!  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2008-09-24 16:13 | wtf110
我动手做了下,真的好用啊!我感觉明白了点aop!谢谢楼主!!  回复  更多评论
  
# re: 一个简单的Spring的AOP例子[未登录] 2009-02-17 23:59 | anna
good  回复  更多评论
  
# re: 一个简单的Spring的AOP例子[未登录] 2009-02-18 00:12 | wen
@Rain
great, 你的注释是画龙点睛一笔阿  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2009-09-30 11:51 | 淡定
No setter found for property 'target' in class 'org.springframework.aop.framework.ProxyFactoryBean'

在第22行中出现。我加入了aop包啊。为什么找不到
22 <property name="target">
23 <ref bean="studenttarget"/>
24 </property>

  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2009-11-05 16:16 |
运行以后会报异常啊
Error creating bean with name 'student' defined in file [E:\workspace\aop2\src\applicationContext.xml]: Cannot resolve reference to bean 'studenttarger' while setting bean property 'targer'; nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No bean named 'studenttarger' is defined  回复  更多评论
  
# re: 一个简单的Spring的AOP例子[未登录] 2009-11-07 19:49 | dragon
@涛
bean id有没有写对?
targer =>target  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2010-02-02 17:19 | Erwin
博主你好!
虽然你的博文已经发表很久了,但是经过一番查找比较,我觉得是最好的!
同时希望能将运行的测试结果贴出来,这样文章才算完整而且方便其他人的阅读。
另:请问能否引用?  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2010-02-10 11:22 | javadragon
@Erwin
可以引用。
最近几个项目都没有用spring,过完年如果有空再整理下,主要还是自己懒,呵呵  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2010-03-10 10:42 | 成亟亟
您好!dragon。
我刚刚接触spring,想跑些小例子熟悉熟悉,由于本人比较愚钝,网上实在是找不到那种step by step的文章,感觉您的文字简洁明了,可是实在是不清楚该怎样把这个例子跑在我的eclipse里,可否把您的工程发给我嘞?谢谢!
scaramouchben@tom.com  回复  更多评论
  
# re: 一个简单的Spring的AOP例子[未登录] 2010-05-03 15:13 | 123
顶,  回复  更多评论
  
# re: 一个简单的Spring的AOP例子[未登录] 2010-07-20 11:56 | 微风
我遇到了和一楼一样的问题,spring.jar包引入了,可还是不行。为什么???  回复  更多评论
  
# re: 一个简单的Spring的AOP例子[未登录] 2010-07-20 16:02 | 微风
搞点了,少了个这个aopalliance-1.0.jar包  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2010-07-27 12:50 | wangsan
3q
  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2010-10-06 20:30 | 查正滨
代码没有任何问题,这个问题我看了好几天,今天终于解决了,谢谢楼主。  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2011-04-12 15:35 | 啊啊啊
代码没有任何问题,也很简单明了,谢谢楼主  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2011-04-13 21:37 | 地痞张三
这个例子很有帮助,谢谢楼主的幸苦劳动  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2011-07-18 14:36 | 产自海南岛的驴肉火烧
小例子很好用,谢谢。  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2011-08-27 09:06 | zhong
代码运行,aop的通知代码没运行出来呢,也没报错  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2011-10-13 16:42 | tesoqop
可以运行,但是aop的通知代码没有运行出来,不知道 为什么。。  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2011-10-13 17:03 | tesoqop
刚才仔细的又看了一遍,发现是自己搞错了。
现在可以啦。afteradvice还没有运行出来。  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2011-10-17 20:12 | ee
如果这就算aop 的话 真的是不难  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2011-11-16 16:44 | 尘埃
不知楼主是否遗忘了这个例子,我看了这个例子后,也运行了,但是我想知道这个程序的运行顺序是什么,就是说在哪配置了它的运行顺序吗(我也没看到啊),为什么就先走before,然后走compareInterceptor,而且这里面怎么去调用impl里的方法的,最后走after?求楼主解答,不胜感激~~  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2011-11-20 19:41 | javadragon
@尘埃
执行顺序是通过继承spring的接口before,afterReturning等来实现的,有兴趣的话,可以去看下spring aop的源码  回复  更多评论
  
# re: 一个简单的Spring的AOP例子 2012-04-23 15:07 |
我觉得你这个例子是调用一个方法并打印,如果参数不满足条件,则不调用方法,和不如直接if,else就可以搞定呢?  回复  更多评论
  

博问 - 解决您的IT难题
博客园  博问  IT新闻  Java程序员招聘
标题  
姓名  
主页
验证码 *  
内容(请不要发表任何与政治相关的内容)  
  登录      


网站导航: