目录
1.有两种动态代理
第一种:有接口情况,使用JDK动态代理
第二种:无接口情况,使用CGLIB动态代理
2.使用JDK动态代理,使用Proxy类里面的方法创建代理对象
步骤一:
步骤二:
步骤三:
3.编写JDK动态代理代码
(1)创建接口,定义方法
(2)创建接口实现类,实现方法
(3)使用Proxy类创建接口代理对象
测试结果:
Spring的AOP-底层原理
1.有两种动态代理
第一种:有接口情况,使用JDK动态代理
步骤:创建接口实现类代理对象,增强类的方法
第二种:无接口情况,使用CGLIB动态代理
步骤:创建子类的代理对象,增强类的方法
2.使用JDK动态代理,使用Proxy类里面的方法创建代理对象
步骤一:
打开JDK8 的开发文档查看的proxy类
步骤二:
往下拉找到一个方法:
步骤三:
调用 newProxyInstance 方法实现JDK动态代理
分析这个方法:
newProxyInstance(ClassLoader loader, 类<?>[] interfaces, InvocationHandler h)
方法有三个参数:
第一个参数 ClassLoader loader:得到类加载器
第二个参数 类<?>[] interfaces:增强方法所在的类,这个类实现的接口,支持多个接口(因为[]代表的是数组)
第三个参数 InvocationHandler h:实现这个接口 InvocationHandler,创建代理对象,写增强的方法
3.编写JDK动态代理代码
(1)创建接口,定义方法
package com.lbj.spring5;public interface UserDao {public int add(int a,int b);public String update(String id);
}
(2)创建接口实现类,实现方法
package com.lbj.spring5;public class UserDaoImpl implements UserDao{@Overridepublic int add(int a, int b) {System.out.println("add方法执行");return a+b;}@Overridepublic String update(String id) {System.out.println("update方法执行");return id;}
}
明确我们要做什么:通过动态代理的方式,add()方法和update()方法做个增强
(3)使用Proxy类创建接口代理对象
代理对象需要传递到代理类中 ,类代理对象是UserDao的实现类
UserDaoImpl中的add()方法需要被增强 ,所以需要把UserDaoImpl的对象传递到代理类中
package com.lbj.spring5;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};//相当于new了一个接口实现类,赋予接口,且这个实现类叫代理类UserDaoImpl userDaoImpl=new UserDaoImpl();//传入对象userDaoImpl//返回代理对象// Object o = Proxy.newProxyInstance(JDKProxy.class.getClassLoader(), interfaces, new UserDaoProxy(userDaoImpl));//强转,接口等于实现类的代理对象UserDao userDao =(UserDao) Proxy.newProxyInstance(JDKProxy.class.getClassLoader(), interfaces, new UserDaoProxy(userDaoImpl));int result = userDao.add(1, 2);System.out.println("result:"+result);}}//创建代理对象代码
class UserDaoProxy implements InvocationHandler{//1.把被代理对象传递进来//如何传递:通过有参构造传递private Object object;public UserDaoProxy(Object object){this.object=object;}//增强的逻辑@Overridepublic Object invoke(Object proxy, Method method, Object[] args) throws Throwable {//方法之前System.out.println("方法执行之前....."+method.getName()+":传递的参数"+ Arrays.toString(args));//被增强的方法执行Object res=method.invoke(object,args);//方法之后System.out.println("方法之后执行...."+object);return res;}
}
测试结果: