栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

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

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

一般我们使用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;


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;


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包

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

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/129975.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号