cglib原理解析_bluespacezero的博客-CSDN博客_cglib实现原理
1、静态代理
通过新建代理类,实现接口生成代理对象。具体的流程如下:
-
代理类中构建有参构造方法,将被代理对象指向代理类中的属性
-
在该代理类中重写接口方法,在方法实体中填充需要增强的逻辑,并调用被代理对象的方法
缺点:
-
如果接口存在多个方法,并且每个方法的增强逻辑一致的情况下,在代理类中会存在重复的增强逻辑。
2、动态代理
动态代理有两种方式,一种是实现接口的JDK动态代理,另一种是继承被代理类的CGLIB动态代理。
-
JDK动态代理
-
自定义一个实现了InvacationHandler接口的处理类,重写该接口的invoke方法,在该方法里实现增强逻辑。
-
利用Proxy.newInstance方法创建代理对象,该代理对象中存在一个属性,该属性实际存储的是实现InvocationHandler接口的子类实例。
-
通过代理对象执行被代理方法时,实际调用的是InvocationHandler接口的子类实例的invoke方法。
-
public final void myMethod() { try { this.h.invoke(this, m3, null); return; } catch (Error | RuntimeException localError) { throw localError; } catch (Throwable localThrowable) { throw new UndeclaredThrowableException(localThrowable); } }
-
CGLIB动态代理
-
自定义一个实现了MethodInterceptor接口的处理类,重写intercept方法,在该方法里实现增强逻辑。
-
通过Enhance创建代理对象,在Enhance实例中设置对应的代理接口以及Callback实现子类(MethodInterceptor接口实现了Callback接口),通过Enhance实例的create方法创建代理对象,该代理对象中存在一个属性,该属性实际存储的是实现MethodInterceptor接口的子类实例。
-
在代理对象调用被代理方法时,实际也是通过该代理对象中存放的实现MethodInterceptor接口的属性,然后调用该属性的intercept方法实现增强逻辑。
-
public final void myMethod() { MethodInterceptor methodInterceptor = this.CGLIB$CALLBACK_0; if (methodInterceptor == null) { Person$$EnhancerByCGLIB$$34b905e4.CGLIB$BIND_CALLBACKS((Object)this); methodInterceptor = this.CGLIB$CALLBACK_0; } if (methodInterceptor != null) { Object object = methodInterceptor.intercept((Object)this, CGLIB$sayHello$0$Method, CGLIB$emptyArgs, CGLIB$sayHello$0$Proxy); return; } super.myMethod(); }