设计模式-CGLIB动态代理

介绍

JDK动态代理的类必须实现接口,CGLIB可以为没有实现接口的类提供代理

使用

1.被代理类:

public class Coder {
    public void work() {
        System.out.println("认真写bug……");
    }
}

2.拦截器:

public class AttendanceMethodInterceptor implements MethodInterceptor {
    @Override
    public Object intercept(Object obj, Method method, Object[] args, MethodProxy proxy) throws Throwable {
        System.out.println("上班打卡……");

        Object result = proxy.invokeSuper(obj, args);

        System.out.println("下班打卡……");

        return result;
    }
}

实现了MethodInterceptor 接口,重写intercept方法。

在执行invokeSuper()方法前后加增强方法。
 

3.代理工厂类:

public class CglibProxyFactory {

    public static Object creatCglibProxyObj(Class<?> clazz) {
        Enhancer enhancer = new Enhancer();
        // 为加强器指定要代理的业务类(即为下面生成的代理类指定父类)
        enhancer.setSuperclass(clazz);
        // 设置回调:对于代理类上所有方法的调用,都会调用CallBack,而Callback则需要实现intercept()方法
        enhancer.setCallback(new AttendanceMethodInterceptor());
        return enhancer.create();
    }

}

测试:

public class Test {

    public static void main(String[] args) {
        Coder coder = (Coder)CglibProxyFactory.creatCglibProxyObj(Coder.class);
        coder.work();
    }

}

输出:

原理

运行时在同名包下产生了3个类

1.代理类

继承了被代理对象,重写了被代理对象非final的方法

2.代理类的索引类

3.被代理类的索引类

4.调用顺序

代理类->自定义方法拦截器->代理类索引类getIndex()方法->代理类索引类invoke()方法->代理类->被代理类

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值