java提供类与cglib包实现动态代理

    终于有点空余时间,决定把之前学习的知识点整理一下,备以后复习。

    动态代理有三角色:抽象角色,代理角色,真是角色。

第一个记录下java提供的动态代理。即使用Proxy类和InvocationHandel接口。直接上贴上代码:

class MyInvocationHandel implements InvocationHandler{
    private Object obj; //这是原对象
    //传入源对象,返回代理对象
    public Object bind(Object obj){
        this.obj=obj;
        return Proxy.newProxyInstance(obj.getClass().getClassLoader(),
                obj.getClass().getInterfaces(), this);
    }

    public Object invoke(Object proxy, Method method, Object[] args)
            throws Throwable {
        System.out.println("用户验证成功");
        Object object=method.invoke(obj, args);
        System.out.println("日志记录:xxx在xx时刻调用了"+method.getName());
        return object;
    }
    
}

 

    通过invocationHandel接口可以代理对象的方法,我们可以加入日志记录等等,代码很简单,功能很强大。

第二个记录下通过cglig包实现的动态代理,比java提供的动态代理优点在于可以提供抽象类方法的代理(不知这样说准确不)。要使用这种代理首先需要导入cglib.jar和asm.jar,然后使用Enhancer类与MethodInterceptor接口,代码:

public class CGlibFactory implements MethodInterceptor{
    private Object targerObj; //原对象
    
        //通过原对象返回代理对象
    public Object createInstance(Object targerObj){
        this.targerObj = targerObj;
        Enhancer en = new Enhancer();
        return en.create(this.targerObj.getClass(),this.targerObj.getClass().getInterfaces(),this);
    }

    public Object intercept(Object proxy, Method method, Object[] args,
            MethodProxy methodProxy) throws Throwable {
        System.out.println("用户验证...");
        Object result= methodProxy.invoke(targerObj, args);
        System.out.println("xx用户调用xx方法");
        return result;
    }
}

 

posted @ 2015-11-26 22:46  钟凯  阅读(1600)  评论(0编辑  收藏  举报