代理模式之CGLIB代理

1:CGLIB代理特点

cglib是针对类来实现代理的
它的原理是对指定的目标类生成一个子类,并覆盖其中方法实现增强
因为采用的是继承,所以不能对final修饰的类进行代理

2:代码实现

2.1:在pom.xml文件中引入cglib的相关依赖

 
<dependency> 
	<groupId>cglibgroupId> 
	<artifactId>cglibartifactId> 
	<version>2.2.2version> 
dependency>

2.2:定义目标类

//可以不用写父类或者实现接口
public class Me {
    public void show(){
        System.out.println("我执行了");
    }
}

2.3:定义代理类,实现接口

/*
        cglib动态代理
 */
public class CglibInterceptor implements MethodInterceptor {
    // 目标对象
    private Object target;
    // 通过构造器传入目标对象
    public CglibInterceptor(Object target) {
        this.target = target;
    }
    /*** 拦截器
     * 1、目标对象的方法调用
     *  2、增强行为
     *  @param o 由CGLib动态生成的代理类实例
     *  @param method 实体类所调用的被代理的方法引用
     *  @param objects 参数值列表
     *  @param methodProxy 生成的代理类对方法的代理引用
     *  @return * @throws Throwable */
    @Override
    public Object intercept(Object o, Method method, Object[] objects, MethodProxy methodProxy) throws Throwable {
        System.out.println("方法执行前。。。");
        Object result = methodProxy.invoke(target, objects);
        System.out.println("方法执行后。。。");
        return result;
    }
    public Object getProxy(){
        // 通过Enhancer对象的create()方法可以生成一个类,用于生成代理对象
        Enhancer enhancer = new Enhancer();
        // 设置父类 (没有父类将目标类作为其父类)
        enhancer.setSuperclass(target.getClass());
        //设置拦截器 回调对象为本身对象
        enhancer.setCallback(this);
        // 生成一个代理类对象,并返回
        return enhancer.create();
    }
}

2.4:代码测试

public class Test {
    public static void main(String[] args) {
        Me me = new Me();
        CglibInterceptor cglib02 = new CglibInterceptor(me);
        Me u = (Me) cglib02.getProxy();
        u.show();
    }
}

你可能感兴趣的:(java框架(新),代理模式,java,开发语言)