基于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();
}
}