java 动态代理范例 InvocationHandler与Proxy

java 动态代理范例 InvocationHandler与Proxy,拦截与代理

java.lang.reflect.Proxy,

Proxy 提供用于创建动态代理类和实例的静态方法.

newProxyInstance()

返回一个指定接口的代理类实例,该接口可以将方法调用指派到指定的调用处理程序

(详见api文档)

java.lang.reflect.InvocationHandler,

InvocationHandler 是代理实例的调用处理程序 实现的接口。

invoke()

在代理实例上处理方法调用并返回结果。在与方法关联的代理实例上调用方法时,将在调用处理程序上

调用此方法。

JDK1.2以后提供了动态代理的支持,程序员通过实现java.lang.reflect.InvocationHandler接口提供一个拦截处理器,然后通过java.lang.reflect.Proxy得到一个代理对象,通过这个代理对象来执行商业方法,在商业方法被调用的同时,执行处理器会被自动调用。

Java动态代理只能对实现了接口的类生成代理,不能针对类。其实现主要是通过java.lang.reflect.Proxy类和java.lang.reflect.InvocationHandler接口。Proxy类主要用来获取动态代理对象,InvocationHandler接口用来约束调用者实现。

接口类源代码:

Java代码

  1. publicinterfaceHelloWorld {
  2. publicvoidsayHelloWorld();
  3. }

实现类源代码:

Java代码

  1. publicclassHelloWorldImpl implementsHelloWorld {
  2. publicvoidsayHelloWorld() {
  3. System.out.println("Hello World!");
  4. }
  5. }

拦截器源代码:

Java代码

  1. publicclassHelloWorldHandler implementsInvocationHandler {
  2. //目标对象
  3. privateObject targetObject;
  4. publicHelloWorldHandler(Object targetObject){
  5. this.targetObject = targetObject;
  6. }
  7. publicObject invoke(Object proxy, Method method, Object[] args) throwsThrowable {
  8. System.out.println("方法调用前。。。");
  9. Object result = method.invoke(this.targetObject, args);
  10. System.out.println("方法调用结束");
  11. returnresult;
  12. }
  13. }

测试代码:

Java代码

  1. publicclassHelloWorldTest {
  2. publicstaticvoidmain(String[] args) {
  3. //业务对象
  4. HelloWorld obj = newHelloWorldImpl();
  5. //拦截器对象
  6. HelloWorldHandler handler = newHelloWorldHandler(obj);
  7. //返回业务对象的代理对象
  8. HelloWorld proxy = (HelloWorld)Proxy.newProxyInstance(
  9. obj.getClass().getClassLoader(),
  10. obj.getClass().getInterfaces(),
  11. handler);
  12. //通过代理对象执行业务对象的方法
  13. proxy.sayHelloWorld();
  14. }
  15. }

测试结果:

Html代码

  1. 方法调用前。。。
  2. Hello World!
  3. 方法调用结束

来自为知笔记(Wiz)