手动实现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();
  }
}

结果:

相关文章
|
3月前
|
Java
Spring5入门到实战------9、AOP基本概念、底层原理、JDK动态代理实现
这篇文章是Spring5框架的实战教程,深入讲解了AOP的基本概念、如何利用动态代理实现AOP,特别是通过JDK动态代理机制在不修改源代码的情况下为业务逻辑添加新功能,降低代码耦合度,并通过具体代码示例演示了JDK动态代理的实现过程。
Spring5入门到实战------9、AOP基本概念、底层原理、JDK动态代理实现
|
12天前
|
存储 缓存 Java
Spring高手之路23——AOP触发机制与代理逻辑的执行
本篇文章深入解析了Spring AOP代理的触发机制和执行流程,从源码角度详细讲解了Bean如何被AOP代理,包括代理对象的创建、配置与执行逻辑,帮助读者全面掌握Spring AOP的核心技术。
25 3
Spring高手之路23——AOP触发机制与代理逻辑的执行
|
2月前
|
设计模式 Java 测试技术
spring复习04,静态代理动态代理,AOP
这篇文章讲解了Java代理模式的相关知识,包括静态代理和动态代理(JDK动态代理和CGLIB),以及AOP(面向切面编程)的概念和在Spring框架中的应用。文章还提供了详细的示例代码,演示了如何使用Spring AOP进行方法增强和代理对象的创建。
spring复习04,静态代理动态代理,AOP
|
3月前
|
缓存 安全 Java
Spring AOP 中两种代理类型的限制
【8月更文挑战第22天】
24 0
|
3月前
|
Java Spring
|
4月前
|
缓存 安全 Java
Spring高手之路21——深入剖析Spring AOP代理对象的创建
本文详细介绍了Spring AOP代理对象的创建过程,分为三个核心步骤:判断是否增强、匹配增强器和创建代理对象。通过源码分析和时序图展示,深入剖析了Spring AOP的工作原理,帮助读者全面理解Spring AOP代理对象的生成机制及其实现细节。
45 0
Spring高手之路21——深入剖析Spring AOP代理对象的创建
|
5月前
|
XML Java 数据格式
Spring5系列学习文章分享---第三篇(AOP概念+原理+动态代理+术语+Aspect+操作案例(注解与配置方式))
Spring5系列学习文章分享---第三篇(AOP概念+原理+动态代理+术语+Aspect+操作案例(注解与配置方式))
48 0
|
2月前
Micronaut AOP与代理机制:实现应用功能增强,无需侵入式编程的秘诀
AOP(面向切面编程)能够帮助我们在不修改现有代码的前提下,为应用程序添加新的功能或行为。Micronaut框架中的AOP模块通过动态代理机制实现了这一目标。AOP将横切关注点(如日志记录、事务管理等)从业务逻辑中分离出来,提高模块化程度。在Micronaut中,带有特定注解的类会在启动时生成代理对象,在运行时拦截方法调用并执行额外逻辑。例如,可以通过创建切面类并在目标类上添加注解来记录方法调用信息,从而在不侵入原有代码的情况下增强应用功能,提高代码的可维护性和可扩展性。
57 1
|
3天前
|
XML Java 开发者
论面向方面的编程技术及其应用(AOP)
【11月更文挑战第2天】随着软件系统的规模和复杂度不断增加,传统的面向过程编程和面向对象编程(OOP)在应对横切关注点(如日志记录、事务管理、安全性检查等)时显得力不从心。面向方面的编程(Aspect-Oriented Programming,简称AOP)作为一种新的编程范式,通过将横切关注点与业务逻辑分离,提高了代码的可维护性、可重用性和可读性。本文首先概述了AOP的基本概念和技术原理,然后结合一个实际项目,详细阐述了在项目实践中使用AOP技术开发的具体步骤,最后分析了使用AOP的原因、开发过程中存在的问题及所使用的技术带来的实际应用效果。
16 5
|
21天前
|
Java 容器
AOP面向切面编程
AOP面向切面编程
37 0