Java中使用动态代理实现拦截器

来源:互联网 发布:linux源码包安装步骤 编辑:程序博客网 时间:2024/05/21 23:32
拦截器在在流行的开源框架中很常见,依赖的技术就是Java的动态代理。
理解拦截器的核心原理对理解这些开源框架的体系结构至关重要。
下面以一个简单的模型的来说明拦截器的实现的一般方法。
 
模型分为以下模块:
业务组件:是被代理和被拦截的对象。
代理处理器:实现了InvocationHandler接口的一个对象
代理对象:Proxy对象。
拦截器:普通的JavaBean,在调用业务方法的之前或者之后会自动拦截并执行自己的一些方法。
客户端:执行业务处理的入口。
 
 
以下是模型的实现

一、业务组件:分为业务接口和业务类
 
public interface BusinessInterface { 
    public void doSomething(); 

 
 
public class BusinessClass implements BusinessInterface{ 

    public void doSomething() { 
        System.out.println("业务组件BusinessClass方法调用:doSomething()"); 
    
}
 
 
二、代理处理器:包含了业务对象绑定动态代理类的处理,并实现了InvocationHandler接口的invoke方法。
 
import java.lang.reflect.InvocationHandler; 
import java.lang.reflect.Method; 
import java.lang.reflect.Proxy; 

 
public class DynamicProxyHandler implements InvocationHandler { 
    private Object business;    //被代理对象 
    private InterceptorClass interceptor = new InterceptorClass();    //拦截器 

     
    public Object bind(Object business) { 
        this.business = business; 
        return Proxy.newProxyInstance( 
                //被代理类的ClassLoader 
                business.getClass().getClassLoader(), 
                //要被代理的接口,本方法返回对象会自动声称实现了这些接口 
                business.getClass().getInterfaces(), 
                //代理处理器对象 
                this); 
    

     
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { 
        Object result = null
        interceptor.before(); 
        result=method.invoke(business,args); 
        interceptor.after(); 
        return null //To change body of implemented methods use File | Settings | File Templates. 
    
}
 
 
三、拦截器:普通的JavaBean,在调用业务方法的之前或者之后会自动拦截并执行自己的一些方法。
 
 
public class InterceptorClass { 
    public void before(){ 
        System.out.println("拦截器InterceptorClass方法调用:before()!"); 
    
    public void after(){ 
        System.out.println("拦截器InterceptorClass方法调用:after()!"); 
    
}
 

四、模拟客户端:执行业务处理的入口。
 
 
public class Client { 
    public static void main(String args[]) { 
        DynamicProxyHandler handler = new DynamicProxyHandler(); 
        BusinessInterface business = new BusinessClass(); 
        BusinessInterface businessProxy = (BusinessInterface) handler.bind(business); 
        businessProxy.doSomething(); 
    
}