CGLib动态代理
由于Jdk动态代理是通过被代理类的接口创建代理对象的,因此JDK动态代理只能代理实现了接口的类的对象,如果一个类没有任何接口,该如何产生代理对象?
CGLib动态代理,是通过创建代理类的子类来创建代理对象的,因此即使没有实现任何接口的类也可以通过CGLib产生代理对象
1、添加CGLib依赖
<dependency>
<groupId>cglib</groupId>
<artifactId>cglib</artifactId>
<version>3.3.0</version>
</dependency>
2、创建被代理类
package com.cn.fb.proxy3;
/**
* @className: MyCalculate
* @Description: MyCalculate
* @Author: liangyongyong
* @Date: 2022/3/4 11:44
* @Version: 1.0.0
*/
public class MyCalculate {
public int add(int a, int b) {
return a + b;
}
public int subtract(int a, int b) {
return a - b;
}
public int multiply(int a, int b) {
return a * b;
}
public int divide(int a, int b) {
return a / b;
}
}
3、创建CGLib代理
package com.cn.fb.proxy3;
import net.sf.cglib.proxy.Enhancer;
import net.sf.cglib.proxy.MethodInterceptor;
import net.sf.cglib.proxy.MethodProxy;
import java.lang.reflect.Method;
/**
* @className: CglibDynamicProxy
* @Description: CglibDynamicProxy
* @Author: liangyongyong
* @Date: 2022/3/5 10:09
* @Version: 1.0.0
*/
public class CglibDynamicProxy implements MethodInterceptor {
private Object obj;
public CglibDynamicProxy(Object obj) {
this.obj = obj;
}
public Object getProxy() {
// Enhancer默认创建子类作为代理类
Enhancer enhancer = new Enhancer();
// 设置Enhancer代理类的父类(也就是说将被代理类作为父类)
enhancer.setSuperclass(obj.getClass());
// 设置Enhancer的回调为this,也就是intercept方法
enhancer.setCallback(this);
final Object proxy = enhancer.create();
return proxy;
}
@Override
public Object intercept(Object o, Method method, Object[] objects, MethodProxy methodProxy) throws Throwable {
final Object invoke = method.invoke(obj, objects);
return invoke;
}
}
4、测试
package com.cn.fb.proxy3;
/**
* @className: Test
* @Description: Test
* @Author: liangyongyong
* @Date: 2022/3/5 10:23
* @Version: 1.0.0
*/
public class Test {
public static void main(String[] args) {
MyCalculate myCalculate = new MyCalculate();
CglibDynamicProxy cglibDynamicProxy = new CglibDynamicProxy(myCalculate);
final MyCalculate proxy = (MyCalculate) cglibDynamicProxy.getProxy();
System.out.println(proxy.add(10, 20));
}
}