CGLib动态代理 java

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
后置代理
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值