手动实现aop使用的动态代理和cglib代理

简介: spring的aop使用的是动态代理和cglib代理,在对象有实现接口的情况下使用动态代理,没有实现接口的情况下使用cglib代理。cglib代理是继承目标对象来创建代理,所以目标对象不能使用final修饰。

spring的aop使用的是动态代理和cglib代理,在对象有实现接口的情况下使用动态代理,没有实现接口的情况下使用cglib代理。

cglib代理是继承目标对象来创建代理,所以目标对象不能使用final修饰。目标对象:

public class TestServiceImpl implements TestService {
  public void save() {
    System.out.println("保存");
  }
  public void update() {
    System.out.println("更改");
  }
  public void delete() {
    System.out.println("删除");
  }
  public void select() {
    System.out.println("查找");
  }
}

动态代理:

package com.vhukze.proxy;
import java.lang.reflect.Method;
import org.springframework.cglib.proxy.InvocationHandler;
import org.springframework.cglib.proxy.Proxy;
import com.vhukze.service.TestService;
import com.vhukze.service.serviceimpl.TestServiceImpl;
/**
* @author zsz
* @version 
* @创建时间:2019年9月18日 上午9:09:17
*/
public class TestServiceProxyFactory {
  private TestServiceImpl service;
  public TestServiceProxyFactory(TestService service) {
    this.service = (TestServiceImpl) service;
  }
  public TestService getTestServiceProxy() {
    //生成动态代理              第一个参数是一个类加载器                        目标对象实现的接口的数组        
    TestService serviceProxy = (TestService) Proxy.newProxyInstance(TestServiceProxyFactory.class.getClassLoader(), TestServiceImpl.class.getInterfaces(), 
                new InvocationHandler() {
                  public Object invoke(Object arg0, Method method, Object[] arg2) throws Throwable {
                    System.out.println("开启事务");
                    //参数一是当前执行此方法的对象 参数二是此方法的参数
                    Object invoke = method.invoke(service, arg2);
                    System.out.println("提交事务");
                    return invoke;
                  }
                });
    return serviceProxy;
  }
}

动态代理:

package com.vhukze.proxy;
import java.lang.reflect.Method;
import org.springframework.cglib.proxy.InvocationHandler;
import org.springframework.cglib.proxy.Proxy;
import com.vhukze.service.TestService;
import com.vhukze.service.serviceimpl.TestServiceImpl;
/**
* @author zsz
* @version 
* @创建时间:2019年9月18日 上午9:09:17
*/
public class TestServiceProxyFactory {
  private TestServiceImpl service;
  public TestServiceProxyFactory(TestService service) {
    this.service = (TestServiceImpl) service;
  }
  public TestService getTestServiceProxy() {
    //生成动态代理              第一个参数是一个类加载器                        目标对象实现的接口的数组        
    TestService serviceProxy = (TestService) Proxy.newProxyInstance(TestServiceProxyFactory.class.getClassLoader(), TestServiceImpl.class.getInterfaces(), 
                new InvocationHandler() {
                  public Object invoke(Object arg0, Method method, Object[] arg2) throws Throwable {
                    System.out.println("开启事务");
                    //参数一是当前执行此方法的对象 参数二是此方法的参数
                    Object invoke = method.invoke(service, arg2);
                    System.out.println("提交事务");
                    return invoke;
                  }
                });
    return serviceProxy;
  }
}

测试方法:

1./**
* @author zsz
* @编辑时间 2019年9月18日上午9:44:03
* @编辑说明  动态代理测试
*/
@Test
public void fun1() {
  TestServiceProxyFactory proxy = new TestServiceProxyFactory(new TestServiceImpl());
  TestService serviceProxy = proxy.getTestServiceProxy();
  serviceProxy.select();
}

结果:

cglib代理:

package com.vhukze.proxy;
import java.lang.reflect.Method;
import org.springframework.cglib.proxy.Enhancer;
import org.springframework.cglib.proxy.MethodInterceptor;
import org.springframework.cglib.proxy.MethodProxy;
import com.vhukze.service.TestService;
import com.vhukze.service.serviceimpl.TestServiceImpl;
/**
* @author zsz
* @version 
* @创建时间:2019年9月18日 上午9:09:17
*/
public class TestServiceProxyFactory2{
  public TestService getTestServiceProxy(){
    //帮我们生成代理对象
    Enhancer en = new Enhancer();
    //设置对谁代理
    en.setSuperclass(TestServiceImpl.class);
    //设置代理要做什么
    en.setCallback(new MethodInterceptor() {
      public Object intercept(Object proxyObj, Method method, Object[] arg, MethodProxy methodProxy) throws Throwable {
        System.out.println("开启事务");
        Object returnValue = methodProxy.invokeSuper(proxyObj, arg);
        System.out.println("提交事务");
        return returnValue;
      }
    });
    return (TestService) en.create();
  }
}

结果:

相关文章
|
1月前
|
监控 Java 开发者
Spring AOP动态代理
Spring AOP动态代理
45 1
|
3月前
|
Java Spring
Spring 源码阅读 72:基于 CGLIB 的 AOP 代理的原理(2)- 拦截器的查找与执行
【1月更文挑战第7天】本文分析了基于 CGLIB 的 AOP 代理如何查找和执行拦截器链,其主要的逻辑在 DynamicAdvisedInterceptor 的intercept方法执行。
35 1
|
3月前
|
Java Spring
Spring 源码阅读 71:基于 CGLIB 的 AOP 代理的原理(1)- DynamicAdvisedInterceptor 分析
【1月更文挑战第6天】本文分析了基于 CGLIB 的 AOP 代理对象,是通过一个 DynamicAdvisedInterceptor 类型的 Callback 来完成 AOP 增强逻辑处理的,DynamicAdvisedInterceptor 通过实现 MethodInterceptor 接口的intercept方法来处理 AOP 增强逻辑。下一篇,将重点分析这个方法的原理。
55 7
|
2月前
|
XML Java 数据格式
浅谈基于动态代理的Spring AOP原理
浅谈基于动态代理的Spring AOP原理
26 0
|
2月前
|
设计模式 安全 Java
深入理解Spring Boot AOP:CGLIB代理与JDK动态代理的完全指南
深入理解Spring Boot AOP:CGLIB代理与JDK动态代理的完全指南
340 1
|
3月前
|
设计模式 Java Spring
Spring AOP基础之代理模式.静态代理和动态代理
Spring AOP基础之代理模式.静态代理和动态代理
30 0
Spring AOP基础之代理模式.静态代理和动态代理
|
3月前
|
XML Java 数据格式
Spring 源码阅读 70:基于 JDK 的 AOP 代理拦截器链执行(4)- 容易被忽略的 ExposeInvocationInterceptor
【1月更文挑战第5天】本文分析了 Spring AOP 拦截器链中的一个特殊拦截器 ExposeInvocationInterceptor 的注册的时机以及它的作用。至此,基于 JDK 的 AOP 代理拦截器链执行的逻辑就分析完了。
397 0
|
2月前
|
Java 数据库连接 应用服务中间件
Spring5源码(39)-Aop事物管理简介及编程式事物实现
Spring5源码(39)-Aop事物管理简介及编程式事物实现
24 0
|
3月前
AOP&面向切面编程
AOP&面向切面编程
55 0
|
3月前
|
Java 程序员 Maven
Spring AOP入门指南:轻松掌握面向切面编程的基础知识
Spring AOP入门指南:轻松掌握面向切面编程的基础知识