Spring4笔记----动态代理

小咪咪 2022-09-24 11:28 201阅读 0赞

代理设计模式的原理: 使用一个代理将对象包装起来, 然后用该代理对象取代原始对象. 任何对原始对象的调用都要通过代理. 代理对象决定是否以及何时将方法调用转到原始对象上.

也就是说在调用原对象的方法的前面和后面,可以加上要实现的追踪代码。这样就解决了原来代码的分散和混乱。使业务逻辑只关心业务。

代码:

  1. package com.spring.aop;
  2. import java.lang.reflect.InvocationHandler;
  3. import java.lang.reflect.Method;
  4. import java.lang.reflect.Proxy;
  5. import java.util.Arrays;
  6. public class ArithmeticCalculatorLoggingProxy {
  7. //要代理的对象
  8. private ArithmeticCalculator target;
  9. //将要代理的对象和代理对象关联起来
  10. public ArithmeticCalculatorLoggingProxy(ArithmeticCalculator target) {
  11. super();
  12. this.target = target;
  13. }
  14. //返回代理对象
  15. public ArithmeticCalculator getLoggingProxy(){
  16. ArithmeticCalculator proxy = null;
  17. ClassLoader loader = target.getClass().getClassLoader();//(1)得到要代理对象的类加载器
  18. Class [] interfaces = new Class[]{ArithmeticCalculator.class};//(2)指定代理对象的类型. 即代理代理对象中可以有哪些方法.
  19. //(3)调用处理器,当代理在调用被代理对象的方法时,会自动调用处理器的invok方法,我们可以把追踪行为的代码放在invoke里面,
  20. InvocationHandler h = new InvocationHandler() {
  21. /**
  22. * invoke方法的三个参数的意义
  23. * proxy: 代理对象。 一般不使用该对象
  24. * method: 正在被调用的方法
  25. * args: 调用方法传入的参数
  26. */
  27. @Override
  28. public Object invoke(Object proxy, Method method, Object[] args)
  29. throws Throwable {
  30. String methodName = method.getName();
  31. //打印日志 在调用运算方法之前和之后来实现追踪行为的代码
  32. System.out.println("[before] The method " + methodName + " begins with " + Arrays.asList(args));
  33. //调用目标方法
  34. Object result = null;
  35. try {
  36. //前置通知
  37. result = method.invoke(target, args);
  38. //返回通知, 可以访问到方法的返回值
  39. } catch (NullPointerException e) {
  40. e.printStackTrace();
  41. //异常通知, 可以访问到方法出现的异常
  42. }
  43. //后置通知. 因为方法可以能会出异常, 所以访问不到方法的返回值
  44. //打印日志
  45. System.out.println("[after] The method ends with " + result);
  46. return result;
  47. }
  48. };
  49. /**
  50. * 需要传给代理的三个参数,
  51. * loader: 代理对象使用的类加载器。
  52. * interfaces: 指定代理对象的类型. 即代理代理对象中可以有哪些方法.
  53. * h: 当具体调用代理对象的方法时, 应该如何进行响应, 实际上就是调用 InvocationHandler 的 invoke 方法
  54. */
  55. //生成代理对象
  56. proxy = (ArithmeticCalculator) Proxy.newProxyInstance(loader, interfaces, h);
  57. return proxy;
  58. }
  59. }

发表评论

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

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

相关阅读

    相关 Spring4笔记----动态代理

    代理设计模式的原理: 使用一个代理将对象包装起来, 然后用该代理对象取代原始对象. 任何对原始对象的调用都要通过代理. 代理对象决定是否以及何时将方法调用转到原始对象上. 也