基于CGLib的动态代理机制,ProxyFactoryy无需再像JDK动态代理那样实现一个interface,实际情况下可能这个interface并不存在,只需要实现另外一个接口MethodInterceptor即可
package com.hmdp.service.尚硅谷的代理模式3;
//CGlib代理import org.springframework.cglib.proxy.Enhancer;
import org.springframework.cglib.proxy.MethodInterceptor;
import org.springframework.cglib.proxy.MethodProxy;import java.lang.reflect.Method;
class TeacherDao {public void teach(){System.out.println("老师授课中...我是CGLib,不需要实现接口");}
}
class ProxyFactory implements MethodInterceptor {
// 维护一个目标对象,被代理对象private Object target;
// 构造器,传入一个被代理对象public ProxyFactory(Object target){this.target = target;}
// 返回一个代理对象,是target对象的代理对象public Object getProxyInstance(){// 1. 创建一个工具类Enhancer enhancer = new Enhancer();
// 2. 设置父类enhancer.setSuperclass(target.getClass());
// 3. 设置回调函数enhancer.setCallback(this);
// 4. 创建子类对象,即代理对象return enhancer.create();}@Override public Object intercept(Object o, Method method, Object[] args, MethodProxy methodProxy) throws Throwable{System.out.println("CGLib代理模式~~开始");Object returnVal = methodProxy.invokeSuper(o, args);System.out.println("CGLib代理模式~~结束");return returnVal;}
}
public class Main {public static void main(String[] args) {
// 创建目标对象TeacherDao target = new TeacherDao();
// 获取到代理对象,并且将目标对象传给代理对象TeacherDao proxyInstance =(TeacherDao) new ProxyFactory(target).getProxyInstance();
// 执行代理对象的方法,触发intercept方法,从而实现对目标对象的调用proxyInstance.teach();}
}