Spring AOP底层实现原理(动态代理)

灰太狼 2022-06-09 14:47 316阅读 0赞

AOP (Aspect Oriented Programing) :面向切面编程,它是一种编程思想。AOP采取横向抽取机制,取代了传统纵向继承体系重复性代码的编写方式(可用于性能监视、事务管理、安全检查、缓存,日志记录等)。

AOP就是要对目标进行代理对象的创建,Spring AOP是基于动态代理的,基于两种动态代理机制:JDK动态代理和CGLIB动态代理。

动态代理和静态代理区别?
动态代理:在虚拟机内部,运行的时候,动态生成代理类(运行时生成,runtime生成) ,并不是真正存在的类。

静态代理:存在代理类 (例如:struts2 Action的代理类 ActionProxy)

JDK代理:基于接口的代理,一定是基于接口,会生成目标对象的接口类型的子对象。

Cglib代理:基于类的代理,不需要基于接口,会生成目标对象类型的子对象。

JDK动态代理

接口

  1. public interface UserService {
  2. void save();
  3. int select();
  4. }

接口实现类

  1. public class UserServiceImpl implements UserService {
  2. @Override
  3. public void save() {
  4. System.out.println("保存用户信息成功");
  5. }
  6. @Override
  7. public int select() {
  8. System.out.println("查询用户信息成功");
  9. return 10;
  10. }
  11. }

JDK动态代理工厂类

  1. public class JdkProxyFactory implements InvocationHandler {
  2. private Object target;
  3. public JdkProxyFactory(Object target) {
  4. this.target = target;
  5. }
  6. /**
  7. * 获取代理对象,当前类继承InvocationHandler
  8. *
  9. * @return
  10. */
  11. public Object getProxyObject() {
  12. return Proxy.newProxyInstance(target.getClass().getClassLoader(), target.getClass().getInterfaces(), this);
  13. }
  14. @Override
  15. public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
  16. //添加功能
  17. System.out.println("增强代码,添加日志功能");
  18. //执行原有方法
  19. return method.invoke(target, args);
  20. }
  21. }

测试JDK动态代理

  1. @Test
  2. public void JdkProxyTest() {
  3. //创建目标对象
  4. UserService userService = new UserServiceImpl();
  5. //创建工厂对象
  6. JdkProxyFactory jdkProxyFactory = new JdkProxyFactory(userService);
  7. UserService proxy = (UserService) jdkProxyFactory.getProxyObject();
  8. proxy.save();
  9. System.out.println("=========================");
  10. proxy.select();
  11. }

CGLIB动态代理

需生成代理对象的类

  1. public class OrderService {
  2. public void save() {
  3. System.out.println("保存订单成功");
  4. }
  5. public int select() {
  6. System.out.println("查询订单成功");
  7. return 10;
  8. }
  9. }

CGLIB动态代理工厂类

  1. public class CglibProxyFactory implements MethodInterceptor {
  2. private Object target;
  3. public CglibProxyFactory(Object target) {
  4. this.target = target;
  5. }
  6. /**
  7. * 获取代理对象
  8. *
  9. * @return
  10. */
  11. public Object getProxyObject() {
  12. Enhancer enhancer = new Enhancer();
  13. //设置两个参数
  14. //设置生成代理类的目标对象(代理类对象是目标对象的子类)
  15. enhancer.setSuperclass(target.getClass());
  16. //设置回调方法
  17. enhancer.setCallback(this);
  18. //生成代理对象
  19. return enhancer.create();
  20. }
  21. @Override
  22. public Object intercept(Object o, Method method, Object[] objects, MethodProxy methodProxy) throws Throwable {
  23. //添加功能
  24. System.out.println("增强代码,添加日志功能");
  25. //执行原有方法
  26. return method.invoke(target, objects);
  27. }
  28. }

测试CGLIB动态代理

  1. @Test
  2. public void CglibProxyTest() {
  3. //创建目标对象
  4. OrderService orderService = new OrderService();
  5. //创建工厂对象
  6. CglibProxyFactory cglibProxyFactory = new CglibProxyFactory(orderService);
  7. OrderService proxy = (OrderService) cglibProxyFactory.getProxyObject();
  8. proxy.save();
  9. System.out.println("=========================");
  10. proxy.select();
  11. }

发表评论

表情:
评论列表 (有 0 条评论,316人围观)

还没有评论,来说两句吧...

相关阅读