Java实现的拦截器模型

导读:
   Java实现的拦截器模型
  
  拦截器在在流行的开源框架中很常见,依赖的技术就是Java的动态代理。
  理解拦截器的核心原理对理解这些开源框架的体系结构至关重要。
  下面以一个简单的模型的来说明拦截器的实现的一般方法。
  
  模型分为以下模块:
  业务组件:是被代理和被拦截的对象。
  代理处理器:实现了InvocationHandler接口的一个对象
  代理对象:Proxy对象。
  拦截器:普通的JavaBean,在调用业务方法的之前或者之后会自动拦截并执行自己的一些方法。
  客户端:执行业务处理的入口。
  
  
  以下是模型的实现
  一、业务组件:分为业务接口和业务类
  /**
  * Created by IntelliJ IDEA.
  * User: leizhimin
  * Date: 2008-3-20 23:32:06
  * Company: LavaSoft(http://lavasoft.blog.51cto.com)
  * 业务组件接口
  */
  publicinterfaceBusinessInterface {
  publicvoiddoSomething();
  }
  
  /**
  * Created by IntelliJ IDEA.
  * User: leizhimin
  * Date: 2008-3-20 23:31:12
  * Company: LavaSoft(http://lavasoft.blog.51cto.com)
  * 业务组件
  */
  publicclassBusinessClass implementsBusinessInterface{
  publicvoiddoSomething() {
  System.out.println("业务组件BusinessClass方法调用:doSomething()");
  }
  }
  
  
  二、代理处理器:包含了业务对象绑定动态代理类的处理,并实现了InvocationHandler接口的invoke方法。
  
  importjava.lang.reflect.InvocationHandler;
  importjava.lang.reflect.Method;
  importjava.lang.reflect.Proxy;
  /**
  * Created by IntelliJ IDEA.
  * User: leizhimin
  * Date: 2008-3-20 23:24:10
  * Company: LavaSoft(http://lavasoft.blog.51cto.com)
  * 动态代理处理器工具
  */
  publicclassDynamicProxyHandler implementsInvocationHandler {
  privateObject business; //被代理对象
  privateInterceptorClass interceptor = newInterceptorClass(); //拦截器
  /**
  * 动态生成一个代理类对象,并绑定被代理类和代理处理器
  *
  * @param business
  * @return 代理类对象
  */
  publicObject bind(Object business) {
  this.business = business;
  returnProxy.newProxyInstance(
  //被代理类的ClassLoader
  business.getClass().getClassLoader(),
  //要被代理的接口,本方法返回对象会自动声称实现了这些接口
  business.getClass().getInterfaces(),
  //代理处理器对象
  this);
  }
  /**
  * 代理要调用的方法,并在方法调用前后调用连接器的方法.
  *
  * @param proxy 代理类对象
  * @param method 被代理的接口方法
  * @param args 被代理接口方法的参数
  * @return 方法调用返回的结果
  * @throws Throwable
  */
  publicObject invoke(Object proxy, Method method, Object[] args) throwsThrowable {
  Object result = null
  interceptor.before();
  result=method.invoke(business,args);
  interceptor.after();
  returnnull //To change body of implemented methods use File | Settings | File Templates.
  }
  }
  
  
  三、拦截器:普通的JavaBean,在调用业务方法的之前或者之后会自动拦截并执行自己的一些方法。
  
  /**
  * Created by IntelliJ IDEA.
  * User: leizhimin
  * Date: 2008-3-20 23:26:31
  * Company: LavaSoft(http://lavasoft.blog.51cto.com)
  * 拦截器
  */
  publicclassInterceptorClass {
  publicvoidbefore(){
  System.out.println("拦截器InterceptorClass方法调用:before()!");
  }
  publicvoidafter(){
  System.out.println("拦截器InterceptorClass方法调用:after()!");
  }
  }
  
  四、模拟客户端:执行业务处理的入口。
  
  /**
  * Created by IntelliJ IDEA.
  * User: leizhimin
  * Date: 2008-3-21 0:32:55
  * Company: LavaSoft(http://lavasoft.blog.51cto.com)
  * 客户端
  */
  publicclassClient {
  publicstaticvoidmain(String args[]) {
  DynamicProxyHandler handler = newDynamicProxyHandler();
  BusinessInterface business = newBusinessClass();
  BusinessInterface businessProxy = (BusinessInterface) handler.bind(business);
  businessProxy.doSomething();
  }
  }
  
  本文出自 “熔 岩” 博客,转载请与作者联系!

本文转自
http://lavasoft.blog.51cto.com/62575/67098
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值