动态代理

public class VectorProxy implements InvocationHandler{
	
	private Object realObject1;
	
	public VectorProxy(Object obj) {
		this.realObject1 = obj;
	}
	
	public static Object factory(Object object) {
		Class<?>  classType = object.getClass();	
		return Proxy.newProxyInstance(classType.getClassLoader(), classType.getInterfaces(),
				new VectorProxy(object));
	}
	
	@Override
	public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
		System.out.println("method:"+method);
		if (args != null) {
			for (Object object : args) {
				System.out.println(object);
			}
		}
		return method.invoke(realObject1, args);
	}
	
	public static void main(String[] args) {
		List v = (List)factory(new Vector());
		v.add("New");
	}
	

}

实例代码如上:

先来看看Proxy类: Proxy 提供用于创建动态代理类和实例的静态方法,它还是由这些方法创建的所有动态代理类的超类。

动态代理类(以下简称为代理类)是一个实现在创建类时在运行时指定的接口列表的类,该类具有下面描述的行为。

代理接口 是代理类实现的一个接口。比如上例中的Vector实现的List接口那么代理接口就是List.

代理实例 是代理类的一个实例。 每个代理实例都有一个关联的调用处理程序 对象(VectorProxy),它可以实现接口 InvocationHandler

通过其中一个代理接口(List)的代理实例上的方法调用将被指派到实例的调用处理程序(VectorProxy)的 Invoke 方法,并传递代理实例、识别调用方法的 java.lang.reflect.Method 对象以及包含参数的 Object 类型的数组。调用处理程序以适当的方式处理编码的方法调用,并且它返回的结果将作为代理实例上方法调用的结果返回。

proxy类的核心方法,动态的生成一个代理类对象的实例,被代理类实现类的一些接口,那么被代理类就宣称实现了这些接口,

即参数中的Interfaces

    public static Object newProxyInstance(ClassLoader loader,
                                          Class<?>[] interfaces,
                                          InvocationHandler h)
        throws IllegalArgumentException

 

然后来看一下InvocationHandler接口:

每个代理实例都具有一个关联的调用处理程序。对代理实例调用方法时,将对方法调用进行编码并将其指派到它的调用处理程序(就是实现了InvocationHandler接口的类)的 invoke 方法。

它里面只有一个方法invoke,方法申明如下:

 public Object invoke(Object proxy, Method method, Object[] args)
        throws Throwable;

Cglib的动态代理

package com.crown.proxy.cglib;

import java.lang.reflect.Method;

import net.sf.cglib.core.DebuggingClassWriter;
import net.sf.cglib.proxy.Enhancer;
import net.sf.cglib.proxy.MethodInterceptor;
import net.sf.cglib.proxy.MethodProxy;


/**
 * 
 * @author Administrator
 *
 */

public class MyIntercepter implements MethodInterceptor {
	
	/*
	 * (non-Javadoc)
	 * @see net.sf.cglib.proxy.MethodInterceptor#intercept(java.lang.Object, java.lang.reflect.Method, java.lang.Object[], net.sf.cglib.proxy.MethodProxy)
	   *    调用处理器相当于JDK动态代理的InvocationHandler的invoke方法
	   *    区别在于cglib生成的是被代理对象的子类,而Jdk动态代理则生成的是与代理类实现了共同接口的实现类。
	 */
	@Override
	public Object intercept(Object obj, Method method, Object[] args, MethodProxy proxy) throws Throwable {
		// TODO Auto-generated method stub
		System.out.println("======插入前置通知======");
        Object object = proxy.invokeSuper(obj, args);
        System.out.println("======插入后者通知======");
		return null;
	}
	
	public static void main(String[] args) {
		Enhancer enhancer = new Enhancer();
		enhancer.setSuperclass(HelloService.class);
		enhancer.setCallback(new MyIntercepter());
		HelloService proxy = (HelloService)enhancer.create();
        proxy.sayHello();
    }
	
}

 

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
毕业设计,基于SpringBoot+Vue+MySQL开发的精简博客系统,源码+数据库+毕业论文+视频演示 当下,正处于信息化的时代,许多行业顺应时代的变化,结合使用计算机技术向数字化、信息化建设迈进。以前企业对于博客信息的管理和控制,采用人工登记的方式保存相关数据,这种以人力为主的管理模式已然落后。本人结合使用主流的程序开发技术,设计了一款基于Springboot开发的精简博客系统,可以较大地减少人力、财力的损耗,方便相关人员及时更新和保存信息。本系统主要使用B/S开发模式,在idea开发平台上,运用Java语言设计相关的系统功能模块,MySQL数据库管理相关的系统数据信息,SpringBoot框架设计和开发系统功能架构,最后通过使用Tomcat服务器,在浏览器中发布设计的系统,并且完成系统与数据库的交互工作。本文对系统的需求分析、可行性分析、技术支持、功能设计、数据库设计、功能测试等内容做了较为详细的介绍,并且在本文中也展示了系统主要的功能模块设计界面和操作界面,并对其做出了必要的解释说明,方便用户对系统进行操作和使用,以及后期的相关人员对系统进行更新和维护。本系统的实现可以极大地提高企业的工作效率,提升用户的使用体验,因此在现实生活中运用本系统具有很大的使用价值。 关键词:博客管理;Java语言;B/S结构;MySQL数据库
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值