一。JDK中使用 实现了InvocationHandler接口的方式来进行动态代理,而cglib则使用 实现了 MethodInterceptor 接口的方式来进行动态代理。
但是,JDK的动态代理依靠接口实现,如果有些类并没有实现接口,则不能使用JDK代理, 这就要使用cglib动态代理了。cglib是针对类来实现代理的,他的原理是对指定的目标类生成一个子类, 并覆盖其中方法实现增强,但因为采用的是继承,所以不能对final修饰的类进行代理。因此,总的来说,用cglib会更好点。
二。准备好相关JAR包,引入JDK,以及 cglib-nodep-2.2.2.jar包等。
三。通过JDK实现的动态代理,例子如下:
IBusi.java
package com.ffcs.icity.proxy.jdk; public interface IBusi { public void test(); }
package com.ffcs.icity.proxy.jdk; public class BusiImpl implements IBusi { @Override public void test() { System.out.println("这边开始进行业务操作."); } }
package com.ffcs.icity.proxy.jdk; import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; import java.lang.reflect.Proxy; /** * JDK动态代理代理类 * @author linwei * */ public class BusiProxy implements InvocationHandler{ private Object target; /** * 绑定委托对象并返回一个代理类 * @param target * @return */ public Object bind(Object target) { this.target = target; //取得代理对象 return Proxy.newProxyInstance(target.getClass().getClassLoader(), target.getClass().getInterfaces(), this); //要绑定接口(这是一个缺陷,cglib弥补了这一缺陷) } @Override /** * 调用方法 */ public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { Object result=null; System.out.println("事物开始"); //执行方法 result=method.invoke(target, args); System.out.println("事物结束"); return result; } }
package com.ffcs.icity.proxy.jdk; /** * 但是,JDK的动态代理依靠接口实现,如果有些类并没有实现接口,则不能使用JDK代理, * 这就要使用cglib动态代理了。 * @author linwei * */ public class TestProxy { public static void main(String[] args) { BusiProxy t = new BusiProxy(); IBusi busi = (IBusi)t.bind(new BusiImpl()); busi.test(); } }
ICgligBusi.java
package com.ffcs.icity.proxy.cglib; public interface ICgligBusi { public void test(); }
package com.ffcs.icity.proxy.cglib; public class CglibBusiImpl implements ICgligBusi { @Override public void test() { System.out.println("这边开始进行业务操作."); } }
package com.ffcs.icity.proxy.cglib; import java.lang.reflect.Method; import net.sf.cglib.proxy.Enhancer; import net.sf.cglib.proxy.MethodInterceptor; import net.sf.cglib.proxy.MethodProxy; /** * 使用cglib进行动态代理工作 * @author linwei * */ public class CglibBusiProxy implements MethodInterceptor { private Object target; /** * 创建代理对象 * * @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(); } @Override // 回调方法 public Object intercept(Object obj, Method method, Object[] args, MethodProxy proxy) throws Throwable { System.out.println("事物开始"); proxy.invokeSuper(obj, args); System.out.println("事物结束"); return null; } }
package com.ffcs.icity.proxy.cglib; /** * cglib是针对类来实现代理的,他的原理是对指定的目标类生成一个子类, * 并覆盖其中方法实现增强,但因为采用的是继承,所以不能对final修饰的类进行代理。 * @author linwei * */ public class TestCglibProxy { public static void main(String[] args) { CglibBusiProxy cglibProxy = new CglibBusiProxy(); ICgligBusi busi = (ICgligBusi)cglibProxy.getInstance(new CglibBusiImpl()); busi.test(); } }