1:CGLIB代理特点
cglib是针对类来实现代理的
它的原理是对指定的目标类生成一个子类,并覆盖其中方法实现增强
因为采用的是继承,所以不能对final修饰的类进行代理
2:代码实现
2.1:在pom.xml文件中引入cglib的相关依赖
<!-- https://mvnrepository.com/artifact/cglib/cglib -->
<dependency>
<groupId>cglib</groupId>
<artifactId>cglib</artifactId>
<version>2.2.2</version>
</dependency>
2.2:定义目标类
//可以不用写父类或者实现接口
public class Me {
public void show(){
System.out.println("我执行了");
}
}
2.3:定义代理类,实现接口
/*
cglib动态代理
*/
public class CglibInterceptor implements MethodInterceptor {
// 目标对象
private Object target;
// 通过构造器传入目标对象
public CglibInterceptor(Object target) {
this.target = target;
}
/*** 拦截器
* 1、目标对象的方法调用
* 2、增强行为
* @param o 由CGLib动态生成的代理类实例
* @param method 实体类所调用的被代理的方法引用
* @param objects 参数值列表
* @param methodProxy 生成的代理类对方法的代理引用
* @return * @throws Throwable */
@Override
public Object intercept(Object o, Method method, Object[] objects, MethodProxy methodProxy) throws Throwable {
System.out.println("方法执行前。。。");
Object result = methodProxy.invoke(target, objects);
System.out.println("方法执行后。。。");
return result;
}
public Object getProxy(){
// 通过Enhancer对象的create()方法可以生成一个类,用于生成代理对象
Enhancer enhancer = new Enhancer();
// 设置父类 (没有父类将目标类作为其父类)
enhancer.setSuperclass(target.getClass());
//设置拦截器 回调对象为本身对象
enhancer.setCallback(this);
// 生成一个代理类对象,并返回
return enhancer.create();
}
}
2.4:代码测试
public class Test {
public static void main(String[] args) {
Me me = new Me();
CglibInterceptor cglib02 = new CglibInterceptor(me);
Me u = (Me) cglib02.getProxy();
u.show();
}
}