AOP底层原理以及JDK动态代理

AOP(概念)
1、什么是AOP
(1)面向切面编程(方面)
利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可复用性,同时也提高了程序开发的效率。
(2)通俗描述:不通过修改源代码方式,再主干功能里面添加新功能

在这里插入图片描述
(3)使用登录例子说明AOP

AOP(底层原理)

1、AOP底层使用动态代理
(1)有两种情况动态代理
(代理就是创建被增强对象的代理对象,通过代理对象实现功能)
第一种 有接口情况,使用JDK动态代理
创建接口实现类的代理对象,增强类的方法
在这里插入图片描述

第二章 没有接口情况,使用CGLIB动态代理
创建当前类子类的代理对象,增强类的方法
在这里插入图片描述

AOP(JDK动态代理)

1、使用JDK动态代理,使用Proxy类里面的方法创建代理对象
在这里插入图片描述
(1)调用 newProxyInstance方法
在这里插入图片描述
方法有三个参数:
第一个参数:ClassLoader 类加载器
interfaces 增强方法所在的类,这个类实现的接口,支持多个接口
实现这个接口InvocationHandler,创建代理对象,写增强的方法
2、JDK动态代理代码
(1)创建接口,定义方法

public interface UserDao {
    public int add(int a, int b);
    public String update(String id);
}

(2)创建接口实现类,实现方法

package com.atguigu.spring5.collectiontype;

public class UserDaoImpl implements  UserDao{
    @Override
    public int add(int a, int b) {
        return a+b;
    }

    @Override
    public String update(String id) {
            return id;
    }
}

(3)使用Proxy类创建接口代理对象

package com.atguigu.spring5.collectiontype;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import java.util.Arrays;

public class JDKProxy {
    public static void main(String[] args){
        //创建接口实现类代理对象
        Class[] interfaces = {UserDao.class};
//        Proxy.newProxyInstance(JDKProxy.class.getClassLoader(), interfaces, new InvocationHandler() {
//            @Override
//            public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
//                return null;
//            }
//        })
        UserDaoImpl userDao = new UserDaoImpl();

        Object dao = (UserDao)Proxy.newProxyInstance(JDKProxy.class.getClassLoader(), interfaces, new UserDaoProxy(userDao));
        int result = ((UserDao) dao).add(1,2);
        System.out.println("result:"+result);
    }
}
//创建代理对象代码

class  UserDaoProxy implements InvocationHandler{
    //1 把创建的是谁的代理对象,把那个谁传递过来
    //有参数构造传递
    private Object obj;
    public UserDaoProxy(Object obj){
        this.obj = obj;
    }



    //增强的逻辑
    @Override
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        //方法之前处理
        System.out.println("在方法之前执行。。。。"+method.getName()+":传递的参数。。。"+ Arrays.toString(args));
        //被增强的方法执行
        Object res = method.invoke(obj, args);
        //方法之后处理
        System.out.println("方法之后执行...."+obj);
        return res;
    }
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SCU Polars

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值