CGLib动态代理
Spring AOP中就用到了动态代理,只不过在Spring中的动态代理分为两类:jdk动态代理和CGLib动态代理。jdk动态代理实现是需要目标类通过接口定义业务方法(其实现见我的博客:http://blog.csdn.net/u013276277/article/details/78532672),对于没有没有接口的目标类就需要使用CGLib。我们这节就是要讲CGLib动态代理的。CGLib动态代理采用了非常底层的字节码技术,其原理是通过字节码技术为一个类创建子类,并在子类中采用方法拦截的技术来拦截所有父类方法的调用,顺势织入横切逻辑。
下面我将给大家举一个CGLib的小例子,首先要做一些准备工作,就是需要两个额外的包 cglib-nodep-2.1_3.jar和aspectjweaver.jar。因为我们需要用到其中的类,所以在使用下面例子前要下载好这两个包,并把它们导入到你们的项目中,
import java.lang.reflect.Method;
import net.sf.cglib.proxy.Enhancer;
import net.sf.cglib.proxy.MethodInterceptor;
import net.sf.cglib.proxy.MethodProxy;
public class CGlibProxy {
public static void main(String[] args) {
CProxy proxy = new CProxy();
SayHello proxyImp = (SayHello)proxy.getProxy(SayHello.class);
proxyImp.say();
}
}
//被代理的类
class SayHello {
public void say() {
System.out.println("hello everyone");
}
}
class CProxy implements MethodInterceptor {
private Enhancer enhancer = new Enhancer();
public Object getProxy(Class clazz) {
//设置需要创建子类的类
enhancer.setSuperclass(clazz);
enhancer.setCallback(this);
//通过创建字节码技术动态创建子类实例
return enhancer.create();
}
@Override
public Object intercept(Object obj, Method method, Object[] args, MethodProxy proxy) throws Throwable {
System.out.println("前置代理");
//通过代理类调用父类中的方法
Object result = proxy.invokeSuper(obj, args);
System.out.println("后置代理");
return result;
}
}
输出结果:
前置代理
hello everyone
后置代理