前篇说过,java自身动态代理是基于接口的。
真正的业务逻辑必须实现你要代理的接口,java在运行时根据接口动态生成一个实现类,该实现类代理了真正的业务逻辑(内部调用业务方法)。
因此是面向接口代理,业务类和代理接口之间是实现关系。
而CGLib则是面向对象代理的,底层是jvm用一个类的字节码创建一个子类,子类代理了真正的业务逻辑,子父类之间是继承关系,所以你要代理的类最好不要申明成final的。
我们用spring的Enhancer来创建代理子类,然后用MethodInterceptor接口来拦截被代理类的方法调用。
public class CGLibProxy implements MethodInterceptor { private Object target;
public Object getCGLibProxy(Object c){ this.target = c; //设置需要创建的子类 enhancer.setSuperclass(c.getClass()); enhancer.setCallback(this); //返回子类实例 return enhancer.create(); } //拦截子类方法 public Object intercept(Object o, Method method, Object[] objects, MethodProxy methodProxy) throws Throwable { System.out.println("前置处理..");// Object obj = methodProxy.invoke(o,objects); Object obj = methodProxy.invoke(target,objects); System.out.println("后置处理.."); return obj; }}private Enhancer enhancer = new Enhancer();
CGLibProxy cgLibProxy = new CGLibProxy(); User user = (User)cgLibProxy.getCGLibProxy(new User()); user.say("miku"); System.out.println("================="); Worker worker = (Worker)cgLibProxy.getCGLibProxy(new Worker()); worker.work("miku");
资料参考
http://www.cnblogs.com/chinajava/p/5880887.html
http://songbo-mail-126-com.iteye.com/blog/968792