CGLIB介绍
在Java中常使用的动态代理有两种:1.JDK的动态代理2.第三方的CGLIB代理
由于JDK的动态代理基于接口(只有接口,才能对目标对象代理),在实际生产中,由于不可能所有的类都有接口,所以基于SAM的CGLIB代理出现了,它的优点是:无需目标对象有接口,之要求它不是final的,因为CGLIB的原理是,继承目标类,来实现代理.
使用CGLIB代理完成HELLO WORD程序
1 . 由于CGLIB是第三方开发的,所以使用之前导入依赖包
<dependency>
<groupId>cglib</groupId>
<artifactId>cglib</artifactId>
<version>3.2.6</version>
</dependency>
2.目标对象
package com.tangdandan.proxy;
/**
* 实现类
*
* @author 唐学俊
* @create 2018/02/04
**/
public class HelloImpl implements Hello{
@Override
public void sayHello(String string) {
System.out.println(string);
}
}
3 . 编写代理对象,实现MethodInterceptor接口
package com.tangdandan.app;
import com.tangdandan.proxy.HelloImpl;
import net.sf.cglib.proxy.Enhancer;
import net.sf.cglib.proxy.MethodInterceptor;
import net.sf.cglib.proxy.MethodProxy;
import java.lang.reflect.Method;
/**
* CGLIB代理
*
* @author 唐学俊
* @create 2018/02/04
**/
public class CGLibProxy implements MethodInterceptor{
private Object target;
/**
* 1.设置对象,来绑定对象
* 2.创建加强器
* 3.为加强器指定要代理的业务
* 4.设置回调
* 5.创建动态代理并返回
*
* @param target 目标对象
* @return
*/
public Object getInstance(Object target){
this.target = target;
Enhancer enhancer = new Enhancer();
enhancer.setSuperclass(this.target.getClass());
enhancer.setCallback(this);
return enhancer.create();
}
/**
* 动态代理对象利用回调,来实现intercept方法拦截
* @param o
* @param method
* @param objects
* @param methodProxy
* @return
* @throws Throwable
*/
@Override
public Object intercept(Object o, Method method, Object[] objects, MethodProxy methodProxy) throws Throwable {
System.out.println("方法处理前");
Object invoke = method.invoke(target, objects);
System.out.println("方法处理后");
return invoke;
}
}
3.执行结果