时间:2021-05-20
本文实例讲述了Java动态代理实现方法。分享给大家供大家参考,具体如下:
静态代理了解的差不多了,但是对于动态代理理解的还不是很通透,这里先把一些常用的动态代理实现方法记录下来,日后时常看看争取早日融会贯通。
1、JDK实现动态代理
主要使用了Proxy.newProxyInstance()方法,该方法的官方解释为:返回一个指定接口的代理类实例,该接口可以将方法调用指派到指定的调用处理程序。
public interface ISomeService { String doFirst(); void doSecond(); String doThird();}//目标类:代理类要增强的类public class SomeServiceImpl implements ISomeService { @Override public String doFirst() { return "AAAbbb"; } @Override public void doSecond() { System.out.println("SomeServiceImpl:执行doSecond()"); } @Override public String doThird() { return "aaa"; }}public class Mytest { public static void main(String[] args) { ISomeService target = new SomeServiceImpl(); ISomeService someService = (ISomeService) Proxy.newProxyInstance( target.getClass().getClassLoader(), target.getClass().getInterfaces(), new InvocationHandler() { // proxy:代理对象 // method:目标方法 // args:目标方法的参数列表 @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { Object result = method.invoke(target, args); if(result!=null) { result=((String)result).toUpperCase(); } return result; } }); System.out.println(someService.doFirst()); someService.doSecond(); System.out.println(someService.doThird()); }}2、CGLIB实现动态代理(没接口)
使用JDK的Proxy实现动态代理,要求目标类与代理类实现相同的接口,若目标类不存在接口,则无法使用该方式实现。
对于没有接口的类,要为其创建动态代理,就要使用CGLIB来实现。CGLIB动态代理的生成原理是生成目标类的子类,而子类是增强过的,这个子类对象就是代理对象。使用CGLIB生成代理类,要求目标类必须能被继承,因此不能是final类。
//目标类:代理类要增强的类public class SomeService { public String doFirst() { System.out.println("SomeServiceImpl:执行doFirst()"); return "AAAbbb"; } public void doSecond() { System.out.println("SomeServiceImpl:执行doSecond()"); }}//注意:使用Cglib动态代理,要求目标类不能是final的//Cglib动态代理的增强原理是:子类增强父类,所以目标类必须能被继承public class CglibFactory implements MethodInterceptor { private SomeService target; public CglibFactory() { } public CglibFactory(SomeService target) { this.target = target; } public SomeService myCglibCreator() { Enhancer enhancer = new Enhancer(); //指定父类,即目标类。因为Cglib动态代理增强的原理是:子类增强父类 enhancer.setSuperclass(SomeService.class); //设置回调接口对象 enhancer.setCallback(this); //create()方法用于创建Cglib动态代理对象 return (SomeService)enhancer.create(); } //回调函数的执行条件:代理对象执行目标方法时会触发该方法 @Override public Object intercept(Object obj, Method method, Object[] args, MethodProxy proxy) throws Throwable { Object invoke = method.invoke(target, args); if(invoke!=null) { invoke=((String)invoke).toUpperCase(); } return invoke; }}public class Mytest { public static void main(String[] args) { SomeService target = new SomeService(); SomeService proxy = new CglibFactory(target).myCglibCreator(); proxy.doFirst(); }}3、CGLIB实现动态代理(有接口)
在有接口的情况下利用CGLIB实现动态代理跟没有接口的情况下利用CGLIB实现动态代理,其实差不多。
public interface ISomeService { String doFirst(); void doSecond(); String doThird();}//目标类:代理类要增强的类public class SomeService implements ISomeService { public String doFirst() { return "AAAbbb"; } public void doSecond() { System.out.println("SomeServiceImpl:执行doSecond()"); } @Override public String doThird() { return "third"; }}//注意:使用Cglib动态代理,要求目标类不能是final的//Cglib动态代理的增强原理是:子类增强父类,所以目标类必须能被继承public class CglibFactory implements MethodInterceptor { private ISomeService target; public CglibFactory() { } public CglibFactory(ISomeService target) { this.target = target; } public ISomeService myCglibCreator() { Enhancer enhancer = new Enhancer(); //指定父类,即目标类。因为Cglib动态代理增强的原理是:子类增强父类 enhancer.setSuperclass(ISomeService.class); //设置回调接口对象 enhancer.setCallback(this); //create()方法用于创建Cglib动态代理对象 return (ISomeService)enhancer.create(); } //回调函数的执行条件:代理对象执行目标方法时会触发该方法 @Override public Object intercept(Object obj, Method method, Object[] args, MethodProxy proxy) throws Throwable { Object invoke = method.invoke(target, args); if(invoke!=null) { invoke=((String)invoke).toUpperCase(); } return invoke; }}public class Mytest { public static void main(String[] args) { ISomeService target = new SomeService(); ISomeService proxy = new CglibFactory(target).myCglibCreator(); System.out.println(proxy.doFirst()); proxy.doSecond(); System.out.println(proxy.doThird()); }}更多java相关内容感兴趣的读者可查看本站专题:《Java面向对象程序设计入门与进阶教程》、《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总》
希望本文所述对大家java程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Java反射机制与动态代理,使得Java更加强大,Spring核心概念IoC、AOP就是通过反射机制与动态代理实现的。1Java反射示例:Useruser=ne
java代理有jdk动态代理、cglib代理,这里只说下jdk动态代理,jdk动态代理主要使用的是java反射机制(既java.lang.reflect包)原理
1.概述JDK动态代理是利用java反射机制生成一个实现接口的匿名类,在调用具体方法前调用InvocationHandler来处理Cglib动态代理是利用asm
Java中动态代理的实现,关键就是这两个东西:Proxy、InvocationHandler,下面从InvocationHandler接口中的invoke方法入
Java语言中反射动态代理接口的解释与演示Java在JDK1.3的时候引入了动态代理机制、可以运用在框架编程与平台编程时候捕获事件、审核数据、日志等功能实现,首