1.JDK动态代理
public class JdkProxyExample implements InvocationHandler{
private Object target = null;
/*JDK动态代理
* JDK动态代理是java.lang.reflect*包提供的方式,它必须借助一个接口才能生成代理对象,所以先定义接口
* 建立代理对象和真实对象的代理关系,并返回代理对象
* @private target真实对象
* @return
* */
public Object bind(Object target){
this.target = target;
/*第1步,建立代理对象和真实对象地关系。这里是使用了bind方法去完成的,方法里面首先用类的属性target保存真实的对象,
* 然后通过如下代码建立
* 其中newProxyInstance方法包含3个参数
* 第一个是类加载器,才用target本身的类加载器
* 第二个是把生成的动态代理对象挂在哪些接口下,这个写法就是放在target实现的接口下
* 第三个定义实现方法逻辑的代理类,this表示当前对象,它必须实现InvocationHandler接口的invoke方法
* 它就是代理逻辑方法的实现方法。*/
return Proxy.newProxyInstance(target.getClass().getClassLoader(), target.getClass().getInterfaces(), this);
}
/*第二步,实现代理逻辑方法。invoke方式可以实现代理逻辑,invoke方法的3个参数的含义
* proxy,代理对象,就是bind方法生成对象
* method,当前调度的方法
* args,调度方法的参数
* 当我们使用了代理对象调度方法后,它就会进入到invoke方法里面*/
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
// TODO Auto-generated method stub
System.out.println("进入代理逻辑方法");
System.out.println("在调度真实对象之前的服务");
Object obj=method.invoke(target, args);
System.out.println("在调度真实对象之后的服务");
return obj;
}
2.CGLIB动态代理
public class Cglibproxy implements MethodInterceptor{
/*
* 生成CGLIB代理对象
* class 类
* @return Class类的CGIB代理对象
* */
public Object getProxy(Class cs){
//CGLIB enhencer 增强对象
Enhancer enhancer = new Enhancer();
//增强类型设置成超类
enhancer.setSuperclass(cs);
//定义代理逻辑对象为当前对象,要求当前对象实现MethodInterceptor的方法intercept
enhancer.setCallback(this);
return enhancer.create();
}
/*代理逻辑方法
* @param arg0代理对象
* @param arg1方法
* @param arg2参数
* @param arg3方法代理
* @return代理逻辑返回
* */
@Override
public Object intercept(Object arg0, Method arg1, Object[] arg2, MethodProxy arg3) throws Throwable {
// TODO Auto-generated method stub
System.err.println("调用真实对象前");
//CGIB反射调用真实对象方法
Object result =arg3.invokeSuper(arg0, arg2);
System.err.println("调用真实对象后");
return result;
}
}
对比适用方式JDK有接口并且不用第三方插件,CGLIB不需要接口,只要一个非抽象类就能实现动态代理