<%@ page contentType="text/html; charset=gb2312"%> 用Java动态代理实现AOP
网站公告:   ◆北天JAVA技术网热情为java爱好者服务,本网内容包括JAVA(JSP、servlet、EJB、webservice、j2ee、javabean、应用服务器、JavaScript),数据库(MYSQL、SQL Server、Sybase、Oracle、DB2、数据库综合知识),设计研究(设计模式、Struts、Spring、Hibernate、设计框架、设计综合知识),WEB2.0新技术(主要介绍AJAX),以及各种技术的入门、实例、例子等等,欢迎各位多来坐坐!◆  诚邀各位JAVA爱好者加盟!◆  本网站内容丰富,更新快,保证每周20篇以上!  
加入收藏
设为首页
联系站长
承接项目
  相关资源:网站首页 | 免费培训学院 | 技术论坛 | JAVA聊天室 | 作家专栏 | 开发工具 | 认证考试 | 会员俱乐部
  JAVA技术初学者园地 | jsp与servlet | javascript | Java源代码 | EJB | web service | 应用服务器 | JAVA综合知识
  设计研究设计模式 | 设计框架 | Struts | Spring | Hibernate | 开源项目 | 面向对象设计 | 设计综合知识
  数 据 库MYSQL | SQL Server | Sybase | Oracle | DB2 | Informix | Access | 数据库综合知识
  其他资源:AJAX新技术 | 网站开发 | ERP软件 | OA办公软件 | 商业智能BI | 开发综合知识 | 承接项目 | 项目试用

 
 
用Java动态代理实现AOP
     发布者: 发布时间:2006-09-08
目前整个开发社区对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。
    
(转载文章请保留出处:北天JAVA技术网(www.java114.com))
 
更多精彩文章:
java入門試題
在 Ajax 应用程序中实现数据交换
BI的发展趋势
BI的应用状况与中外差距分析
BI的市场分析
BI的实施
 
最近评论:
        
冰封的往事!
wow power leveling,wow gold,wow power leveling,wow gold max(5048)
        
冰封的往事!
wow power leveling,wow gold,WoW Gold,wow gold max(2100)
        
冰封的往事!
wow power leveling,wow gold,WoW Gold,wow gold max(8320)
        
冰封的往事!
wow power leveling,wow gold,WoW Gold,wow gold max(8869)
        
飞舞的传奇!
传世私服,传世私服.传奇世界私服传奇世界私服,传世私服传世私服, 传奇世界私服传奇世界私服.传奇私服传奇私服. max(66)
        
Nestor
4311425e446406e511a79116f269ef25 http://milano-pietro-ostacolo.tzlnou.biz/ http://scala-retrattile-legno.iuatju.biz/ http://presupposto-avviso-liquidazione.kajgdw.biz/ http://formazione-organizzazione.iuatju.biz/ http://convertitore-usb-wireless.ygvhik.biz/ http://antea-pit-bull-roma.kajgdw.biz/ http://mediolanum-assicurazione-commento.iuatju.biz/ http://parcheggio-aeroporto-napoli.ygvhik.biz/ http://siviglia-feria-de-tapa.enadzh.biz/ http://castel-sant-angelo-medioevo.iuatju.biz/ 69fae163d26a9b1682339a4eb6fc4ad9
        
Rashad
56dd032b1f61e5bdb22a404714a4d9a2 http://strada-regionale-numero-2.cqhnnx.org/ http://tumore-della-tiroide.cqhnnx.org/ http://mannheim-germania.pvaeyo.org/ http://legge-malattia-bambino.cqhnnx.org/ http://vetrina-esposizioni.gbdrme.org/ http://gas-4-fuochi.vywyuh.org/ http://ufficio-stampa-comune-milano.gbdrme.org/ http://giardiniera-sott-olio-o-aceto.cqhnnx.org/ http://scarica-mp3-zero-7.mnkcbe.org/ http://assicurazione-rca.jnbwct.org/ eb89aa2351bfb8dd061b0dc25061dcdb
        
Dontae
2b1dd395aedbe3cf246ac1fafe9bd75e BlaylockRoman MustafaKost IsaiahHugh SpelmanGene PargaAmos BurrisXavier PorterOstrander AaronCeleste DamianPrimavera BlaylockRoman 1bb5907b91a875f331998f8e4f2b0572
        
Michael
dcb52f18612c4f3ca6c3b81deaaa011c http://daniele-cascella-compito-classe.aoknmm.in/ http://mimmo-zingaro-provveditore.licoxi.in/ http://converte-immagini.kmyeyh.com/ http://week-end-8-dicembre.jvzulp.in/ http://paola-chiara-marco.miwcjz.com/ http://annuncio-personale-treviso.miwcjz.com/ http://cricket-isernia.kmyeyh.com/ http://punto-informatica.licoxi.in/ http://stufe-catalitiche.kvpzig.com/ http://la-tv-sul-pc.uylqdg.com/ b8a12f78e2ab8d9c8e5e94f78e975725
        
Landen
http://ab870605052eac4d90e430550546262a-t.xkktxb.org ab870605052eac4d90e430550546262a [url]http://ab870605052eac4d90e430550546262a-b1.xkktxb.org[/url] [url=http://ab870605052eac4d90e430550546262a-b2.xkktxb.org]ab870605052eac4d90e430550546262a[/url] [u]http://ab870605052eac4d90e430550546262a-b3.xkktxb.org[/u] 8d1f2bfe3cbc5359328d95464cab8b7c
        
标 题:   
内 容:   
 
                                  
 
免责声明:该文章由网友发表,如果对您造成侵权,请联系站长

首页 - 承接项目 - 网站地图 - 联系我们 -
版权所有北天JAVA技术工作室 ICP证号:粤ICP备06079815号