- 浏览: 18302 次
- 性别:
- 来自: 西安
最新评论
Proxy Pattern:对其他对象提供一种代理以控制对这个对象的访问,它的主要作用是为其他对象提供一种代理以控制对这个对象的访问。在某些情况下,一个对象不想或者不能直接引用另一个对象,而代理对象可以在客户端和目标对象之间起到中介的作用
1)
Subject.java
package com.flyingh.isubject; public interface Subject { void fun1(); void fun2(); void fun3(); }
RealSubject.java
package com.flyingh.subject; import com.flyingh.isubject.Subject; public class RealSubject implements Subject { @Override public void fun1() { // TODO Auto-generated method stub System.out.println("fun1()"); } @Override public void fun2() { // TODO Auto-generated method stub System.out.println("fun2()"); } @Override public void fun3() { // TODO Auto-generated method stub System.out.println("fun3()"); } }
Proxy.java
package com.flyingh.subject; import com.flyingh.isubject.Subject; public class Proxy implements Subject { private Subject realSubject; public Proxy(Subject realSubject) { super(); this.realSubject = realSubject; } public void before() { System.out.println("before"); } public void after() { System.out.println("after"); } @Override public void fun1() { // TODO Auto-generated method stub before(); realSubject.fun1(); } @Override public void fun2() { // TODO Auto-generated method stub before(); realSubject.fun2(); after(); } @Override public void fun3() { // TODO Auto-generated method stub realSubject.fun3(); after(); } }
Client.java
package com.flyingh.client; import com.flyingh.isubject.Subject; import com.flyingh.subject.Proxy; import com.flyingh.subject.RealSubject; public class Client { public static void main(String[] args) { Subject proxy = new Proxy(new RealSubject()); proxy.fun1(); proxy.fun2(); proxy.fun3(); } }
程序运行结果如下:
before fun1() before fun2() after fun3() after
2)Dynamic Proxy:
(1):
Subject.java
package com.flyingh.isubject; public interface Subject { void print(); }
RealSubject.java
package com.flyingh.subject; import com.flyingh.isubject.Subject; public class RealSubject implements Subject { @Override public void print() { // TODO Auto-generated method stub System.out.println("hello world!!!"); } }
DynaProxy.java
package com.flyingh.proxy; import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; import java.lang.reflect.Proxy; public class DynaProxy implements InvocationHandler { private Object obj; public DynaProxy(Object obj) { super(); this.obj = obj; } public Object newProxyInstance() { return Proxy.newProxyInstance(obj.getClass().getClassLoader(), obj .getClass().getInterfaces(), this); } @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { // TODO Auto-generated method stub before(); Object retObj = method.invoke(obj, args); after(); return retObj; } private void after() { // TODO Auto-generated method stub System.out.println("after()"); } private void before() { // TODO Auto-generated method stub System.out.println("before()"); } }
Client.java
package com.flyingh.client; import com.flyingh.isubject.Subject; import com.flyingh.proxy.DynaProxy; import com.flyingh.subject.RealSubject; public class Client { public static void main(String[] args) { Subject proxy = (Subject) new DynaProxy(new RealSubject()) .newProxyInstance(); proxy.print(); } }
程序运行结果如下:
before() hello world!!! after()
(2):
Subject.java
package com.flyingh.subject; public class Subject { public void print() { System.out.println("hello world!!!"); } }
CglibProxy.java
package com.flyingh.proxy; import java.lang.reflect.Method; import net.sf.cglib.proxy.Enhancer; import net.sf.cglib.proxy.MethodInterceptor; import net.sf.cglib.proxy.MethodProxy; public class CglibProxy implements MethodInterceptor { private Object obj; public CglibProxy(Object obj) { super(); this.obj = obj; } public Object newProxyInstance() { Enhancer enhancer = new Enhancer(); enhancer.setSuperclass(obj.getClass()); enhancer.setCallback(this); return enhancer.create(); } @Override public Object intercept(Object obj, Method method, Object[] args, MethodProxy proxy) throws Throwable { // TODO Auto-generated method stub before(); Object retObj = proxy.invoke(this.obj, args); after(); return retObj; } private void after() { // TODO Auto-generated method stub System.out.println("after()"); } private void before() { // TODO Auto-generated method stub System.out.println("before()"); } }
Client.java
package com.flyingh.client; import com.flyingh.proxy.CglibProxy; import com.flyingh.subject.Subject; public class Client { public static void main(String[] args) { Subject proxy = (Subject) new CglibProxy(new Subject()) .newProxyInstance(); proxy.print(); } }
程序运行结果如下:
before() hello world!!! after()
发表评论
文章已被作者锁定,不允许评论。
-
Interpreter
2011-11-24 21:19 839Interpreter Pattern:其意图是给定一个语言, ... -
Visitor
2011-11-24 17:37 659Visitor Pattern:表示一个作用于某对象结构中的各 ... -
Mediator
2011-11-24 16:22 662Mediator Pattern: 用一 ... -
Prototype
2011-11-24 11:32 605Prototype Pattern:就是通过复制现在已经存在的 ... -
Memento
2011-11-23 21:56 685Memento Pattern:在不破坏封闭的前提下,捕获一个 ... -
Flyweight
2011-11-23 18:38 651享元模式以共享的方式高效地支持大量的细粒度对象. 1).Fl ... -
Builder
2011-11-22 16:38 763Builder Pattern:可以将一个产品的内部表象与产品 ... -
Bridge
2011-11-22 15:05 684桥梁模式的用意是"将抽象化(Abstraction) ... -
Chain Of Responsibility
2011-11-21 23:05 658Chain Of Responsibility Pattern ... -
Abstract Factory
2011-11-21 22:00 644下面以Mac和PC的CPU和RAM为例,代码如下: Cpu. ... -
State
2011-11-18 15:57 678State Pattern:当一个对象的内在状态改变时允许改变 ... -
Composite
2011-11-17 17:09 793Composite Pattern:意图是将对象组合成树形结构 ... -
Iterator
2011-11-16 16:56 889Iterator Pattern:其意图是提供一种方法顺序访问 ... -
Template Method
2011-11-16 11:43 659模板方法模式:在一个方法中定义一个算法的骨架,而将一些实 ... -
Facade
2011-11-15 23:00 596Facade Pattern:为子系统中的各类(或结构与方法) ... -
Adapter
2011-11-15 21:43 630Adapter Pattern:将一个类的接口,转换成客户所期 ... -
Command
2011-11-14 23:06 5721).下面以Boss和Clerk为例: Clerk.java ... -
Factory Method
2011-11-13 20:44 595Simple Factory: 以Fruit为例,以下是实现 ... -
Decorator
2011-11-12 23:09 570装饰者可以在所委托被装饰者的行为之前与/或之后,加上自己的 ... -
Observer
2011-11-12 21:30 600观 察 者 模 式 定义了对象之间的一对多依赖,这样一来 ...
相关推荐
配置时同样需要将`proxy.ashx`部署到服务器,并在ArcGIS JavaScript API中设置`proxyUrl`属性。 **proxy.php** 是PHP语言实现的代理服务,适用于PHP环境,如Apache或Nginx。对于那些基于PHP的Web应用,可以使用`...
Proxy和Stub的作用是解决进程间通信的问题,使得不同地址空间的应用程序可以透明地调用彼此的功能。 3. **MergeModule (x86)**:MergeModule是一个MSI(Microsoft Installer)模块,用于将组件打包到安装程序中。...
在SAP系统中,ABAP调用ABAP Proxy是一种常见的技术操作,用于在不同系统间或者同一系统内的组件之间实现通信。ABAP Proxy是SAP提供的一个强大的接口技术,它允许开发者创建安全、高效的远程调用机制。接下来,我们将...
在讨论Nginx的proxy_redirect指令时,我们首先要明确其在Nginx配置中的作用和重要性。proxy_redirect指令主要用于在反向代理过程中修改响应头中的Location和Refresh字段值。在Web服务器配置中,特别是在使用Nginx...
《GoProxy-Android:全能代理服务器在安卓平台的应用与实现》 GoProxy-Android是由snail007/goproxy团队开发的一款适用于安卓系统的全能代理服务器应用。此项目旨在为移动设备提供强大的网络代理功能,使得用户能够...
接下来我们将深入探讨标题和描述中涉及的“sharding-proxy实现分表”这一主题。 ### 1. 分库分表介绍 分库分表是数据库水平扩展的一种常见策略,用于解决单表数据量过大导致的性能问题。随着业务的增长,数据量...
FoxyProxy 是一款高级代理服务器管理工具,是 Firefox 火狐浏览器的代理插件,相比比 SwitchProxy、ProxyButton、QuickProxy、xyzproxy、ProxyTex 等扩展提供更多的功能。 FoxyProxy 通过使用通配符、正则表达式和...
《InfluxDB与Influx-Proxy的深度解析》 InfluxDB是一款专为时间序列数据设计的开源数据库,尤其在监控、物联网(IoT)、性能指标和其他大数据领域有着广泛的应用。而"Influx-proxy"则可能是一个针对InfluxDB的代理...
Google Chrome插件: Proxy SwitchOmega 2.5.15. 轻松快捷地管理和切换多个代理设置. 离线插件使用方法: 1. 打开Chrome -> 自定义及控制按钮(右上角) -> 更多工具 -> 扩展程序 (有可能需要打开开发者模式) 2. 拖拽...
"ArcGIS JS API跨域配置 Proxy 代理" ArcGIS JS API 跨域配置是指在 JS 开发中遇到的访问本地服务和外网服务的问题,需要使用 Proxy 代理来解决跨域访问文件的问题。ArcGIS 的帮助中已经有了相关的介绍和使用配置。...
Proxy和Mycat是两种常用的中间件,用于实现这些功能。本篇文章将深入探讨proxy和Mycat的对比测试,以及如何在MySQL主从架构中进行测试。 首先,我们来看proxy。Proxy通常指的是数据库代理服务器,它位于应用服务器...
`dma-proxy.c`、`dma-proxy-test.c`、`dma-proxy.h` 这些文件名暗示了它们在实现或测试dma-proxy的功能中起到的作用: 1. `dma-proxy.c`: 这通常是一个C语言源代码文件,其中包含了dma-proxy的主要实现逻辑。它可能...
在本文中,我们将深入探讨“proxy代理程序”的概念以及如何实现一个简单的代理服务。网络编程是计算机科学中的一个重要领域,而代理程序在此中扮演着关键角色,它允许客户端通过中间服务器来访问其他网络资源,从而...
MySQL Proxy 是一个开源工具,由 MySQL AB 公司开发,允许用户在 MySQL 客户端和服务器之间插入一个代理层。这个代理层可以用来监控、分析或者修改通信数据,为数据库管理提供了一种灵活的解决方案。`mysql-proxy-...
proxy源代码,linux下的ftp 代理的源代码,大家多多支持啊
proxy2proxy 多级协议代理软件当前支持32/64位Windows7/8/10等操作系统。 proxy2proxy 多级协议代理软件特点: 1)支持单级/多级协议代理服务。 2)支持 HTTP/HTTPS 协议网络代理。 3)支持大规模网络...
在这个配置中,Nginx监听8080端口,当接收到CONNECT请求时,会尝试连接到配置的`$proxy_host:$proxy_port`。 使用该模块需要注意一些安全问题,因为透明代理可能被滥用为攻击跳板或绕过防火墙策略。为了安全起见,...
【JsProxy:在线JavaScript代理与离线打包工具】 JsProxy是一个强大的在线JavaScript处理工具,它提供了两种主要功能:JavaScript代理(js proxy)和JavaScript打包(js packer)。这两个功能对于前端开发者来说是...