由于jdk默认实现只能对接口进行代理,对普通类就不行了。所以Cglib正是为了弥补这种不足开发的。原理是对指定的目标类生成一个子类,并覆盖其中方法实现增强。因为采用的是继承,所以不能对final修饰的类进行代理。
采用上一篇类似的代码:
一个普通类(未明确指明实现接口)
public class DoSomethingImpl2 {
public void doA() {
System.out.println("I'm DoSomethingImpl2...");
}
}完成一个cglib代理类
import java.lang.reflect.Method;
import net.sf.cglib.proxy.*;
public class DoSomethingCglib implements MethodInterceptor{
private Object target;
public Object getInstance(Object target){
this.target=target;
Enhancer enhancer = new Enhancer();
enhancer.setSuperclass(target.getClass());
enhancer.setCallback(this);
return enhancer.create();
}
@Override
public Object intercept(Object obj, Method method, Object[] args,
MethodProxy proxy) throws Throwable {
Object result;
System.out.println("Cglib代理准备...");
result=proxy.invokeSuper(obj, args);
System.out.println("Cglib代理完成...");
return result;
}
}一个测试类
public class TestProxy {
public static void main(String[] args){
DoSomethingCglib dscg=new DoSomethingCglib();
DoSomethingImpl2 dsi2CgProxy=(DoSomethingImpl2)dscg.getInstance(new DoSomethingImpl2());
dsi2CgProxy.doA();
}
}
本文介绍了CGLIB代理机制的原理及其在Java开发中的应用,通过实例展示了如何使用CGLIB对普通类进行代理增强。文章深入探讨了CGLIB与Java反射机制的区别,并提供了完整的代码实现。
1925

被折叠的 条评论
为什么被折叠?



