CGLib代理

来源:互联网 发布:sqlserver删除历史数据 编辑:程序博客网 时间:2024/05/18 13:45

前篇说过,java自身动态代理是基于接口的。

真正的业务逻辑必须实现你要代理的接口,java在运行时根据接口动态生成一个实现类,该实现类代理了真正的业务逻辑(内部调用业务方法)。

因此是面向接口代理,业务类和代理接口之间是实现关系。


而CGLib则是面向对象代理的,底层是jvm用一个类的字节码创建一个子类,子类代理了真正的业务逻辑,子父类之间是继承关系,所以你要代理的类最好不要申明成final的。

我们用spring的Enhancer来创建代理子类,然后用MethodInterceptor接口来拦截被代理类的方法调用。


public class CGLibProxy implements MethodInterceptor {    private Object target;
    private Enhancer enhancer = new Enhancer();
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; }}

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



原创粉丝点击