当前位置:七道奇文章资讯编程技术Java编程
日期:2011-03-22 16:15:00  来源:本站整理

<b>用Java动态代理实现AOP</b>[Java编程]

赞助商链接



  本文“<b>用Java动态代理实现AOP</b>[Java编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:

目前整个开辟社区对AOP(Aspect Oriented Programing)推崇备至,也涌现出大量支持AOP的优异Framework,--Spring, JAC, Jboss AOP 等等.AOP仿佛一时之间成了潮流.Java初学者不由要发出感触,OOP还没有学通呢,又来AOP.本文不是要在理论上具体阐述作甚AOP, 为什么要举行AOP . 要具体理解学习AOP可以到它故乡http://aosd.net去瞧瞧.这里只是企图通过一个简单的例子向初学者展示一下若何来举行AOP.

为了简单起见,例子没有没有利用任何第三方的AOP Framework, 而是操纵Java语言本身自带的动态代理功效来实现AOP.

让我们先回到AOP本身,AOP主要利用于日记记录,性能统计,安全掌握,事件处理等方面.它的主要企图就要将日记记录,性能统计,安全掌握等等代码从商业逻辑代码中清楚的划分出来,我们可以把这些行为一个一个单独看做系统所要办理的问题,就是所谓的面向问题的编程(不知将AOP译作面向问题的编程能否不当).通过对这些行为的别离,我们但愿可以将它们独立地配置到商业办法中,而要改变这些行为也不需求影响到商业办法代码.

假定系统由一系列的BusinessObject所完成业务逻辑功效,系统要求在每一次业务逻辑处理时要做日记记录.这里我们略去具体的业务逻辑代码.

public interface BusinessInterface {
  public void processBusiness();
}
public class BusinessObject implements BusinessInterface {
  private Logger logger = Logger.getLogger(this.getClass().getName());
  public void processBusiness(){
   try {
    logger.info("start to processing...");
    //business logic here.
    System.out.println(“here is business logic”);
    logger.info("end processing...");
   } catch (Exception e){
    logger.info("exception happends...");
    //exception handling
   }
  }
}

这里处理商业逻辑的代码和日记记录代码混合在一同,这给日后的保护带来一定的艰难,并且也会造成大量的代码反复.完好相同的log代码将呈目前系统的每一个BusinessObject中.

按照AOP的思惟,我们应当把日记记录代码别离出来.要将这些代码别离就触及到一个问题,我们必须知道商业逻辑代码什么时刻被调用,这样我们好插入日记记录代码.普通来说要截获一个办法,我们可以采取回调办法大概动态代理.动态代理普通要越发机动一些,目前大都的AOP Framework也大都采取了动态代理来实现.这里我们也采取动态代理作为例子.

JDK1.2今后供应了动态代理的支持,程序员通过实现java.lang.reflect.InvocationHandler接口供应一个履行处理器,然后通过java.lang.reflect.Proxy得到一个代理对象,通过这个代理对象来履行商业办法,在商业办法被调用的同时,履行处理器会被自动调用.

有了JDK的这种支持,我们所要做的仅仅是供应一个日记处理器.

public class LogHandler implements InvocationHandler {
  private Logger logger = Logger.getLogger(this.getClass().getName());
   private Object delegate;
   public LogHandler(Object delegate){
    this.delegate = delegate;
   }
  public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
   Object o = null;
   try {
    logger.info("method stats..." + method);
    o = method.invoke(delegate,args);
    logger.info("method ends..." + method);
   } catch (Exception e){
    logger.info("Exception happends...");
    //excetpion handling.
   }
   return o;
  }
}

目前我们可以把BusinessObject里面的全部日记处理代码全部去掉了.

public class BusinessObject implements BusinessInterface {
  private Logger logger = Logger.getLogger(this.getClass().getName());
  public void processBusiness(){
   //business processing
   System.out.println(“here is business logic”);
  }
}

客户端调用商业办法的代码以下:

BusinessInterface businessImp = new BusinessObject();
InvocationHandler handler = new LogHandler(businessImp);
BusinessInterface proxy = (BusinessInterface) Proxy.newProxyInstance(
  businessImp.getClass().getClassLoader(),
  businessImp.getClass().getInterfaces(),
  handler);
proxy.processBusiness();

程序输出以下:

INFO: method stats...
here is business logic
INFO: method ends...

至此我们的第一次小尝试算是完成了.可以看到,采取AOP之后,日记记录和业务逻辑代码完好脱离了,今后要改变日记记录的话只需求改正日记记录处理器就行了,而业务对象本身(BusinessObject)无需做任何改正.并且这个日记记录不会造成反复代码了,全部的商业处理对象都可以重用这个日记处理器.

当然在实际利用中,这个例子就显得太粗糙了.由于JDK的动态代理并没有直接支持一次注册多个InvocationHandler,那么我们对业务处理办法既要日记记录又要性能统计时,就需求自己做一些变通了.普通我们可以自己定义一个Handler接口,然后保护一个行列存放全部Handler, 当InvocationHandler被触发的时刻我们顺次调用自己的Handler.所幸的是目前几近全部的AOP Framework都对这方面供应了很好的支持.这里举荐大家利用Spring.


  以上是“<b>用Java动态代理实现AOP</b>[Java编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • <b>hosts是什么 hosts文件在什么位置 若何改正hosts</b>
  • <b>在 Windows 8 中手动安装语言包</b>
  • <b>五个常见 PHP数据库问题</b>
  • Windows中Alt键的12个高效快速的利用本领介绍
  • <b>MySQL ORDER BY 的实现解析</b>
  • <b>详解MySQL存储历程参数有三种范例(in、out、inout)</b>
  • <b>Win8系统恢复出来经典的开始菜单的办法</b>
  • <b>Win8系统花屏怎么办 Win8系统花屏的办理办法</b>
  • <b>Windows 7系统下无线网卡安装</b>
  • <b>为什么 Linux不需求碎片整理</b>
  • <b>Windows 8中删除账户的几种办法(图)</b>
  • <b>教你如安在win7下配置路由器</b>
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .