网管联盟 | 网管论坛 | 网管u家 | 网管博客 | 网管软件 | 网管求职 | 小游戏 | 网管搜索 | 网管原创 | 网管聚合 | 网管读摘 | 网管焦点 | 世界素材 | 会员投稿 | 会员中心 
中国网管联盟
Windows Linux Cisco 网络技术 数据库 黑客攻防 DotNet Java PHP 认证 新闻资讯 服务器 存储资讯 网络设备 网管学堂 技术专题 焦点 网吧频道
 当前位置: > bitsCN.com > JAVA > 开源技术 > Spring > Spring AOP之Hello World  

Spring AOP之Hello World

2004-09-24  作者:BitsCN整理  来源:中国网管联盟  点评 投稿 收藏


  我们使用一个简单的例子来演示一下Spring中的AOP,这是一个log的例子,实际上log是一个对于AOP来说很不好的例子,这里我们只为说明Spring AOP的使用。
  
  1.首先我们来创建一个自己的interceptor
  这个类必须继承org.aopalliance.intercept. MethodInterceptor接口。Spring的AOP框架就是参照aopalliance这个标准实现的,所以我们的MyInterceptor要继承这个标准中的接口。
  这个接口只有一个要求实现的方法:
  public Object invoke(MethodInvocation methodInvocation) throws Throwable;
  下面是我们的MyIntercptor:
  
  public class MyInterceptor implements MethodInterceptor {
  private final Log logger = LogFactory.getLog(getClass());
  
  public Object invoke(MethodInvocation methodInvocation) throws Throwable {
  logger.info("Beginning method (1): " +
  methodInvocation.getMethod().getDeclaringClass() + "." +
  methodInvocation.getMethod().getName() + "()");
  long startTime = System.currentTimeMillis();
  try{
  Object result = methodInvocation.proceed();

网管bitscn_com


  return result;
  }finally{
  logger.info("Ending method (1): " +
  methodInvocation.getMethod().getDeclaringClass() + "." +
  methodInvocation.getMethod().getName() + "()");
  logger.info("Method invocation time (1): " +
  (System.currentTimeMillis() - startTime) + " ms.");
  }
  }
  }
  
  对于上面的代码需要说明的是下面两行代码:
  Object result = methodInvocation.proceed();
  return result;
  整个程序的流程是这样的:
  1,先是执行在Object result = methodInvocation.proceed();前面的代码;
  2,接着执行Object result = methodInvocation.proceed();,它把执行控制权交给了interceptor stack(拦截器栈)内的下一个interceptor,如果没有了就交给真正的业务方法;
  3,然后执行return result;之前的代码;
  4,最后执行return result;,它把控制权交回它之上的interceptor,如果没有了就退出interceptor stack。
  
  2.写出我们的业务对象及其接口
  为了方便我们的业务接口只有一个hello方法:
  
  public interface BusinessInterface {

网管u家u.bitscn@com


  public void hello();
  }
  
  业务对象的代码如下:
  
  public class BusinessInterfaceImpl implements BusinessInterface{
  public void hello() {
  System.out.println("hello Spring AOP.");
  }
  }
  
  3.接下来,我们来看看如何使用我们的写的interceptor
  我们把业务对象作为AOP的target:
  <bean id="businessTarget" class="com.rst.spring.testaop.BusinessInterfaceImpl"/>
  接着在bean定义中声明interceptor:
  <bean id="myInterceptor" class="com.rst.spring.testaop.MyInterceptor"/>
  最后,我们来声明真正的业务对象,通过使用它的接口以及Spring的ProxyFactoryBean:
  
  <bean id="businessBean"
    class="org.springframework.aop.framework.ProxyFactoryBean">
  <property name="proxyInterfaces">
  <value>com.rst.spring.testaop.BusinessInterface</value>
  </property>
  <property name="interceptorNames">
  <list>
  <value>myInterceptor</value>
  <value>businessTarget</value>

中国网管论坛bbs.bitsCN.com


  </list>
  </property>
  </bean>
  
  这里需要说明两点:
  proxyInterfaces:就是我们的业务对象的实际接口;
  interceptorNames:定义了所有interceptors的执行顺序,其中业务对象的target作为list的最后一个。记着一定要把业务对象的target放到list中,否则你的业务对象就不会工作。
  
  4.最后,写我们的测试类
  ClassPathResource resource =
  new ClassPathResource("com/rst/spring/testaop/aop_bean.xml");
  XmlBeanFactory beanFactory = new XmlBeanFactory(resource);
  BusinessInterface businessBean =
  (BusinessInterface) beanFactory.getBean("businessBean");
  businessBean.hello();
  
  一切正常就可以在log上看到相应的信息了。
  以下是附件源代码的执行效果:
  2004-09-08 16:04:51,210 INFO - Beginning method (1): interface com.rst.spring.testaop.BusinessInterface.hello()
  2004-09-08 16:04:51,210 INFO - Beginning method (2): interface com.rst.spring.testaop.BusinessInterface.hello()
  hello Spring AOP.
  2004-09-08 16:04:51,210 INFO - Ending method (2): interface com.rst.spring.testaop.BusinessInterface.hello() 网管论坛bbs_bitsCN_com
  2004-09-08 16:04:51,210 INFO - Ending method (1): interface com.rst.spring.testaop.BusinessInterface.hello()
  2004-09-08 16:04:51,210 INFO - Method invocation time (1): 0 ms.
  源代码需要spring.jar, aopallience.jar, commons-logging.jar。
  

TAGs   业务   对象   接口   执行   interceptor   代码    
 上一篇:Spring Reference   下一篇:spring,ioc模式与ejb3的SLSB实现
相关文章列表
Spring AOP之Hello World 评论:
loading.. 评论加载中…
评论:请自觉遵守互联网相关政策法规,评论不得超过250字。

验证码: 注册用户
本类热门排行:
1.详细的 spring 入门实例讲解运用
2.spring+hibernate+jbpm整合成功
3.Struts+Spring+Hibernate实现上传下载
4.整合 JSF+Spring+Hibernate的小例子
5.用Spring更好地处理Struts动作三种整合
6.Spring与iBATIS的集成
7.Spring AOP之Hello World
8.Spring MVC验证的配置步骤
9.基于Spring例子的JPetStore分析
10.WEB开发中Spring AOP实际应用一例
最新推荐文章:
1.应用spring示例开发网站构思
2.Spring 数据源配置与应用
3.Spring中的四种声明式事务的配置
4.spring.net 学习笔记之AOP
5.Spring DAO之JDBC
6.Struts 2, spring 2, hibernate 的整合
7.spring 编程入门十大问题解答
8.Spring与struts整合开发实例(一)
9.spring入门几个问题及解决
10.Spring框架概述
网管论坛交流:
·不疯魔不成活
·令你大开眼界的真正标准化机房,已整理重
·为赈灾,女孩舍身拍“裸照”
·Windows Server 2003服务器群集创建和配
·exchange2k3全套官方资料
·双儿一周岁了。。。特殊的礼物来啦。。
·存储备份技术版块守则
·无盘技术交流区守则
·DOS命令基础大全之命令详解<作者吐血
·Windows XP 操作系统默认设置需要注意的