Aop动态代理和cglib实现代码详解

时间:2021-05-20

一般我们使用Aop对象时,常用动态代理模式,即是采用映射一个相同的类在此基础上进行前置后置操作。

动态代理多是采用原类实现父类接口,然后动态代理一个和原类相同的双胞胎兄弟类来实现映射。

父类

public interface InterF { public void save();}

需要映射的类

public class Origin implements InterF{ @Override public void save() { System.out.println("测试一下"); }}

动态代理映射,此类需要传入相应的原类对象

import java.lang.reflect.InvocationHandler;import java.lang.reflect.Method;import java.lang.reflect.Proxy;/** * @author bai * @create 2019-10-25-16:47 */public class ProxyJdk implements InvocationHandler { private Object target; public Object getProxy(Object target){ this.target=target; return Proxy.newProxyInstance(this.getClass().getClassLoader(),target.getClass().getInterfaces(),this); } @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { System.out.println("我来了"); Object invoke = method.invoke(target, args); System.out.println("我走了"); return invoke; }}

测试类

public class Mytest { public static void main(String[] args) { Origin o=new Origin(); ProxyJdk pj=new ProxyJdk(); InterF proxy = (InterF) pj.getProxy(o); proxy.save(); }}

复制代码

cglib模式的代理和动态代理大同小异,模式上相同,但cglib采用的是直接实现父子类,继承原类来实现映射。

原类

public class Origin{ public void save() { System.out.println("测试一下"); }}

cglib映射类,此类也需要传入原类

import net.sf.cglib.proxy.Enhancer;import net.sf.cglib.proxy.MethodInterceptor;import net.sf.cglib.proxy.MethodProxy;import java.lang.reflect.Method;/** * @author bai * @create 2019-10-25-17:26 */public class CglibProxy implements MethodInterceptor{ private Object target;//被代理目标 public Object getProxy(Object target){ this.target=target; Enhancer enhancer = new Enhancer();//1.设置基类 enhancer.setSuperclass(target.getClass());//2.设置回调接口 enhancer.setCallback(this);//MethodInterceptor实现类//3.创建动态代理 return enhancer.create(); } @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; }}

o是传入的对象,method是相应的切点所切方法,objects即参数。

测试类

public class Mytest2 { public static void main(String[] args) { Origin o=new Origin(); CglibProxy cp=new CglibProxy(); Origin proxy = (Origin) cp.getProxy(o); proxy.save(); }}

cglib相对于动态代理少了一个父类,更加便捷。且cglib使用时需要导入相应的jar包

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章