我们这次主要介绍的是BlazeDS,基于Java的一个AMF实现。也是Adobe 官方给出的一个开源实现。
源码SVN:
http://opensource.adobe.com/svn/opensource/blazeds/
下载带Tomcat服务器的整合包,解压后可以直接运行,体验例子:
http://flexorg.wip3.adobe.com/blazeds/3.0.x/milestone/3978/blazeds-turnkey-3.2.0.3978.zip
下载部署包,仅仅源码所必须的内容:
http://flexorg.wip3.adobe.com/blazeds/3.0.x/milestone/3978/blazeds-bin-3.2.0.3978.zip
在对其文件结构和配置进行介绍前,我先介绍一下BlazeDS的结构。 这个图翻译自Adobe的BlazeDS官方文档
在BlazeDS中,其结构被设计为多层的传递式构建。
端点(Endpoint) (在MessageBrokerServlet中实现)
我们一般可以看到,BlazeDS暴露的Endpoint有几种
- 提供远程方法调用的
这种endpoint是最常见的一种endpoint,其默认形式是 /messagebroker/amf 或者如果通过https协议访问则是/messagebroker/amfsecure - 提供普通http服务端
普通HTTP服务其是就是我们最常见的一些以xml形式或者逗号分割符的形式返回纯文本内容的形式。这里不加详细分析 其默认访问形式 /messagebroker/http 或者 /messagebroker/httpsecure - 提供消息流的
所谓消息流其实是Steaming, 他的含义通过标准的HTTP协议,提供防火墙穿透力很强的即时信息服务。其实现原理是客户端发出一个HTTP请求,服务器会将这个http请求放入休眠状 态。由于http协议的特性,一个请求如果没有返回,则这个请求的tcp/ip连接是保持的。 当服务器端有消息的时候,他会激活这个睡眠的线程请求,让其返回。客户端收到这个返回后,会重新发出一个新的请求,用于取出服务器上的消息。然后重复等 待。这个endpoint的形式一般为 /messagebroker/streamingamf - 提供服务器polling的.
polling也就是我们所说的刷服务器法。 每隔一定的时间间隔,刷新服务器去获取新的消息更新。这个方法跟steaming方式的不同在于,其效率比steaming低,而且他没有steaming提供的消息即时性好。
服务(Services)
我们看到,一个来自客户端的请求,通过MessageBrokerServlet捕获后,根据请求服务种类,转交给不同服务。
这里有
- 远程方法调用服务
远程方法调用也就是我们最常用的一种服务调用方式,其作用是在Flex客户端调用服务器上的某个方法,取得其返回结果。 - 代理服务
代理服务应该用在某些特殊场合,比如客户端需要调用企业内部的某个服务器上的webservice,而客户端又处于企业防火墙外部,这种情况下,通过 BlazeDS的代理服务,可以让客户端通过BlazeDS服务器(位于企业防火墙之内而又暴露了对外访问的服务器),去访问防火墙内部的某个服务。 另外,当遇到某些服务需要跨域策略文件(crossdomain,xml)的时候,可以通过代理来实现。 - 消息服务
消息服务主要是为Flex客户端提供一个健壮的消息服务接口,你可以通过JMS适配器直接和一些企业级的消息服务器直接连接。
目标(Destination)
目标其实是一个请求的目标:
对于常用的远程方法调用来说,其目标(destination)就是某个特定的java服务,或者某个特定的配置好的Java类
对于代理目标来说,则是定义好的代理种类,比如说普通HTTP代理还是基于WebService的代理
对于消息目标来说,则是某个特定的消息服务种类。
适配器(Adapter)
适配器的作用是提供多种实现来提供某种特定的服务
对于远程调用来说,BlazeDS提供了一个默认的JavaAdapter.这个适配器允许你调用服务器上的一个Java类,实际上,还有EJBAdapter,他可以让你的远程调用服务调用一个EJB的方法。
对于代理服务来说,一个不同的适配器意味着你可以访问不同种类的代理资源,这里的例子是基于普通HTTP的代理以及基于SOAP的代理
对于消息服务来说,如果提供JMS适配器,则能让你连接到标准的JMS服务器来交换消息。如果提供一个Actionscript适配器,则可以让你在你的Flex客户端之间交换信息。