spring aop jdk动态代理简单实现

aop jdk动态代理

  1. 使用jdk 动态代理,使用Proxy类中的方法 创建代理对象

    //这个方法 是      Proxy类      中的方法
    public static Object newProxyInstance(ClassLoader loader,Class<?>[] interfaces,InvocationHandler h)throws IllegalArgumentException
    
    1. 方法中含有三个参数
      1. 第一个 类加载器
      2. 第二个 增强方法所在的类 这个类实现的接口 支持多个接口
      3. 第三个 实现这个接口 InvocationHandler 创建代理对象
  2. jdk 动态代理代码

    1. 创建接口 定义方法

      package com.zh.demo1;
      
      public interface UserDao {
          public int add(int a,int b);
          public String update(String id);
      }
      
  3. 创建接口的实现类 实现方法

    package com.zh.demo1;
    
    public class UserDaoImpl implements UserDao{
        @Override
        public int add(int a, int b) {
            return a+b;
        }
    
        @Override
        public String update(String id) {
            return id;
        }
    }
    
  4. 使用Proxy类创建接口代理对象

    1. 创建一个类 创建main方法
    2. 实现Proxy中newProxyInstance 方法 方法含有三个参数 上边写了 第一个参数是类的加载器 为JDKProxy.class.getClassLoader() 第二个参数为增强方法所在的类 举例为userdao 第三个参数一个接口用来创建代理对象 两种方法 1 匿名内部类 直接new 2 创建一个新的类实现此接口 我采用的为此方法
public class JDKProxy {
    private Object object;
    public static void main(String[] args) {
        //创建接口实现类的代理对象
        Class[] interfaces={UserDao.class};
        UserDaoImpl userDao=new UserDaoImpl();
        UserDao dao = (UserDao) Proxy.newProxyInstance(JDKProxy.class.getClassLoader(),
         interfaces,
          new UserDaoProxy(userDao));
        int add=dao.add(1,2);
        System.out.println(add);
    }
}

//实现这个接口需要实现一个方法   invoke  表示增强的逻辑
class UserDaoProxy implements InvocationHandler{
    //1 把创建的是 谁的代理对象 把谁传递过来
    //通过有参构造进行传递  对应上边
    private Object object;
    public UserDaoProxy(Object object){
        this.object=object;
    }
    //增强的逻辑
    @Override  
    //第一个参数 代理对象 第二个值 表示当前的方法  第三个 表示方法的参数
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        //方法之前   原方法执行前可以加入
        //method.getName()执行的方法名字
        System.out.println("方法之前执行"+method.getName()+":传递的参数====="+ Arrays.toString(args));

        //被增强的方法
        //下面表示执行当前方法  
        Object a=method.invoke(object,args);
        //方法之后   原方法执行后可以加入
        System.out.println("方法之后执行      "+object);
        return a;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring AOP中的JDK动态代理是一种实现动态代理的方式。它通过使用JDK的Proxy类和InvocationHandler接口来生成代理对象和处理代理逻辑。具体来说,当我们使用Spring AOP时,代理对象的生成直接使用了JDK动态代理的Proxy.newProxyInstance方法。而代理逻辑则是通过实现了InvocationHandler接口的invoke方法来实现的。在Spring AOP中,JdkDynamicAopProxy类实现了InvocationHandler接口,并完成了Spring AOP拦截器链拦截等一系列逻辑。通过JdkDynamicAopProxy的invoke方法,我们可以在目标方法执行前后添加额外的逻辑。这种方式的优点是可以在运行时动态地生成代理对象,不需要事先编写代理类的代码。这样可以更加灵活地实现横切关注点的功能,并且可以避免代码冗余。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Spring AOP --JDK动态代理方式](https://blog.csdn.net/m0_46195271/article/details/108714116)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [SpringAOP JDK动态代理](https://blog.csdn.net/weixin_46281472/article/details/125629339)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值