`

设计模式:代理模式(Proxy Pattern)

阅读更多


代理模式

代理模式为其他对象提供一种代理以控制对这个对象的访问。在某些情况下,一个 客户不想或者不能直接引用另一个对象,而代理对象可以在客户端和目标对象之间 起到中介的作用。

 

 

 

代理模式一般涉及到三个角色

1>抽象角色:声明真实对象和代理对象的共同接口;

2>代理角色:代理对象角色内部含有对真实对象的引用,从而可以操作真实对象,同时代理对象提供与真实对象相同的接口以便在任何时刻都能代替真实对象。同时,代理对象可以在执行真实对象操作时,附加其他的操作,相当于对真实对象迚行封装。

3>真实角色:代理角色所代表的真实对象,是我们最终要引用的对象。

 

 

一、我们自己建一个简单的代理模式

1.新建一个抽象角色:Subject接口 

 

package com.kaishengit.proxy;

public interface Subject {
	public void sales();//销售
}

 

 2.新建一个真实角色:RealSubject(实现Subject接口)

 

package com.kaishengit.proxy;
//Dell
public class RealSubject implements Subject{

	@Override
	public void sales() {
		System.out.println("Dell销售电脑");
	}

}

 

 3.新建一个代理角色:SubjectProxy(实现Subject接口) 

 

package com.kaishengit.proxy;

//代理
public class SubjectProxy implements Subject{
	
	private Subject subject;
	
	/**
	 * 传进去要代理的对象
	 * @param subject
	 */
	public SubjectProxy(Subject subject){
		this.subject = subject;
	}
	@Override
	public void sales() {
		System.out.println("忽悠");//销售之前做点...
		subject.sales();
		System.out.println("送东西");//销售之后做点...
	}

}

 

 4.我们测试一下:

 

package com.kaishengit.proxy;

public class Test {
	public static void main(String[] args) {
		//被代理对象
		RealSubject rs = new RealSubject();
		
		//代理
		SubjectProxy sp = new SubjectProxy(rs);
		
		sp.sales();
	}
}

 

 运行结果:

--------------------------------------

 

忽悠

Dell销售电脑

送东西

 

--------------------------------------

 

ok......

 

 

二、Java动态代理

Java中动态代理一定要面向接口编程,也就是被代理对象必须实现接口,这是Java动态代理的缺陷。Java动态代理借助的是InvocationHandler接口。

Spring中的AOP使用到Java动态代理

 

1.由于被代理对象必须实现接口,我们先新建一个接口(Dao)

 

package com.kaishengit.proxy.java;

public interface Dao {
	public void save();
}

 接下来我们创建被代理对象(实现接口):UserDao

 

package com.kaishengit.proxy.java;

public class UserDao implements Dao{

	@Override
	public void save() {
		System.out.println("save success!");
	}

}
 

2.我们创建一个实现InvocationHandler接口的类:MyInvocationHandler

 

package com.kaishengit.proxy.java;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;

public class MyInvocationHandler implements InvocationHandler{
	
	private Object obj;
	
	//传进去被代理对象
	public MyInvocationHandler(Object obj){
		this.obj = obj;
	}
	
	@Override
	public Object invoke(Object proxy, Method method, Object[] args)
			throws Throwable {
		System.out.println("before");//之前做点什么
		Object result = method.invoke(obj, args);//执行被代理对象的方法
		System.out.println("after");//之后做点什么
		return result;
	}

}

 3.我们测试一下:

 

 

package com.kaishengit.proxy.java;

import java.lang.reflect.Proxy;

public class Test {
	public static void main(String[] args) {
		UserDao ud = new UserDao();//被代理对象
		
		MyInvocationHandler mih = new MyInvocationHandler(ud);//我们新建的实现InvocationHandler接口的类
		//创建代理proxyDao
		Dao proxyDao = (Dao) Proxy.newProxyInstance(ud.getClass().getClassLoader(), ud.getClass().getInterfaces(), mih);
		
		proxyDao.save();
	}
}

 运行结果:

------------------------------------------

 

before

save success!

after

------------------------------------------

 

三、使用CGLib进行动态代理

需要导入cglib的jar包,原理:如果被代理对象没有实现接口,动态产生一个子类来实现代理模式;否则采用Java动态代理模式。需要借助的是cglib包中的MethodInterceptor接口。

Spring中就导入了cglib的jar包,因为其中的AOP用到代理模式,以应对被代理对象没有实现接口

 

1.我们新建一个被代理对象:UserDao(呵呵,没有实现任何接口啊)

 

package com.kaishengit.proxy.cglib;

public class UserDao {
	public void save(){
		System.out.println("save success!");
	}
}

2.我们新建一个类实现 MethodInterceptor接口:DaoIntercept

 

 

package com.kaishengit.proxy.cglib;

import java.lang.reflect.Method;

import net.sf.cglib.proxy.MethodInterceptor;
import net.sf.cglib.proxy.MethodProxy;

public class DaoIntercept implements MethodInterceptor{

	@Override
	public Object intercept(Object object, Method method, Object[] args,
			MethodProxy methodProxy) throws Throwable {
		System.out.println("before");//执行之前做点...
		//注意是methodProxy和invokeSuper
		Object result = methodProxy.invokeSuper(object, args);
		System.out.println("after");//执行之后做点...
		return result;
	}

}

 3,我们测试一下:

 

package com.kaishengit.proxy.cglib;

import net.sf.cglib.proxy.Enhancer;

public class Test {
	public static void main(String[] args) {
		UserDao dao = new UserDao();
		
		//Enhancer同样是cglib包中的
		Enhancer enhancer = new Enhancer();
		enhancer.setSuperclass(dao.getClass());
		enhancer.setCallback(new DaoIntercept());
		
		//创建代理对象
		UserDao proxyDao = (UserDao) enhancer.create();
		proxyDao.save();
	}
}

 运行结果:

----------------------------------------------------

 

before

save success!

after

----------------------------------------------------

 

----end----

 

2
0
分享到:
评论

相关推荐

    Android设计模式之代理模式(Proxy Pattern)

    Android设计模式之代理模式(Proxy Pattern)

    java 设计模式之代理模式(Proxy Pattern)实现代码及设计详解:动态代理模式、静态代理模式

    java 代理模式实现代码及设计详解:动态代理模式、静态代理模式

    36种最新设计模式整理

    36种最新设计模式整理 Design Pattern: Simple Factory 模式 Design Pattern: Abstract Factory 模式 Design Pattern: Builder 模式 Design Pattern: Factory Method 模式 Design Pattern: Prototype 模式 ...

    设计模式:可复用面向对象软件的基础--详细书签版

     “[设计模式]在实用环境下特别有用,因为它分类描述了一组设计良好,表达清楚的面向对象软件设计模式。整个设计模式领域还很新,本书的四位作者也许已占据了这个领域造诣最深的专家中的半数,因而他们定义模式的方法...

    代理模式 Proxy Pattern

    在代理模式(Proxy Pattern)中,一个类代表另一个类的功能。这种类型的设计模式属于结构型模式。 在代理模式中,我们创建具有现有对象的对象,以便向外界提供功能接口。

    设计模式PPT

     代理模式(Proxy Pattern) 行为型模式用来对类或对象怎样交互和怎样分配职责进行描述,主要包含以下11种设计模式:  责任链模式(Chain of Responsibility Pattern)  命令模式(Command Pattern)  解释...

    Python设计模式之代理模式实例详解

    代理模式(Proxy Pattern):为其他对象提供一种代理以控制对这个对象的访问 #!/usr/bin/env python # -*- coding:utf-8 -*- __author__ = 'Andy' """ 大话设计模式 设计模式——代理模式 代理模式(Proxy Pattern):为...

    C++设计模式(Design Pattern)范例源代码

    23种设计模式(Design Pattern)的C++实现范例,包括下面列出的各种模式,代码包含较详细注释。另外附上“设计模式迷你手册.chm” 供参考。 注:项目在 VS2008 下使用。 创建型: 抽象工厂模式(Abstract Factory) ...

    设计模式 之 “代理模式[Proxy Pattern]”

    NULL 博文链接:https://lym6520.iteye.com/blog/692896

    C#设计模式-吕震宇

    C#设计模式(13)-Proxy Pattern C#设计模式(12)-Decorator Pattern C#设计模式(11)-Composite Pattern C#设计模式(10)-Adapter Pattern C#设计模式(9)-Prototype Pattern C#设计模式(8)-Builder ...

    32种设计模式

    代理模式(Proxy Pattern) 13. 模板方法(Template Method) 14. 命令模式(Command Pattern) 15. 迭代器模式(Iterator Pattern) 行为型: 16. 观察者模式(Observer Pattern) 17. 解释器...

    用Java实现23种设计模式

    代理模式(Proxy Pattern) 3. 行为型模式 责任链模式(Chain of Responsibility Pattern) 命令模式(Command Pattern) 解释器模式(Interpreter Pattern) 迭代器模式(Iterator Pattern) 中介者模式...

    C#设计模式_设计模式_C#_

    代理模式(Proxy Pattern) 行为型: 13. 模板方法(Template Method) 14. 命令模式(Command Pattern) 15. 迭代器模式(Iterator Pattern) 16. 观察者模式(Observer Pattern) 17. 解释器模式(Interpreter Pattern) 18....

    33种JAVA设计模式DEMO

    代理模式(Proxy Pattern) 3 行为型模式 这些设计模式特别关注对象之间的通信。 责任链模式(Chain of Responsibility Pattern) 命令模式(Command Pattern) 解释器模式(Interpreter Pattern) 迭代器模式...

    C#版 24种设计模式

    备忘录模式(Memento Pattern) 策略模式(Strategy Pattern) 抽象工厂模式(Abstract Factory Pattern) 代理模式(Proxy Pattern) 单例模式(Singleton Pattern) 迭代器模式(Iterator Pattern) 访问者模式(Visitor ...

    Java24种设计模式,Java24种设计模式,24种设计模式,学会了这24种设计模式,可以打遍天下无敌手,设计模式非常重要

    2、代理模式PROXY PATTERN 3、单例模式SINGLETON PATTERN 4、多例模式MULTITION PATTERN 5、工厂方法模式FACTORY METHOD PATTERN 6、抽象工厂模式ABSTRACT FACTORY PATTERN 7、门面模式FACADE PATTERN 8、适配器...

    24种设计模式与6大设计原则

    代理模式[PROXY PATTERN] 单例模式[SINGLETON PATTERN] 多例模式[MULTITION PATTERN] 工厂方法模式[FACTORY METHOD PATTERN] 抽象工厂模式[ABSTRACT FACTORY PATTERN] 门面模式[FACADE PATTERN] 适配器模式[ADAPTER ...

    C#设计模式.PDF

    C#设计模式(13)-Proxy Pattern 113 一、 代理(Proxy)模式 113 二、 代理的种类 114 三、 远程代理的例子 114 四、 代理模式的结构 115 五、 代理模式示例性代码 115 六、 高老庄悟空降八戒 117 七、 不同类型的...

    [源代码] 《易学 设计模式》 随书源代码

    第11章 越俎代庖:代理模式 (Proxy) 第12章 真人不露相:装饰模式 (Decorator) 第13章 游刃有余:桥模式 (Bridge) 第14章 如法炮制:组合模式 (Composite) 第15章 源源不断:享元模式 (Flyweight) 第16章 按部就班:...

Global site tag (gtag.js) - Google Analytics