Spring与BlazeDS的整合之BlazeDS介绍(2)

我们这次主要介绍的是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.zi

在对其文件结构和配置进行介绍前,我先介绍一下BlazeDS的结构。 这个图翻译自Adobe的BlazeDS官方文档

 

在BlazeDS中,其结构被设计为多层的传递式构建。

端点(Endpoint) (在MessageBrokerServlet中实现)

我们一般可以看到,BlazeDS暴露的Endpoint有几种

  1. 提供远程方法调用的
    这种endpoint是最常见的一种endpoint,其默认形式是 /messagebroker/amf 或者如果通过https协议访问则是/messagebroker/amfsecure
  2. 提供普通http服务端
    普通HTTP服务其是就是我们最常见的一些以xml形式或者逗号分割符的形式返回纯文本内容的形式。这里不加详细分析 其默认访问形式  /messagebroker/http 或者 /messagebroker/httpsecure
  3. 提供消息流的
    所谓消息流其实是Steaming, 他的含义通过标准的HTTP协议,提供防火墙穿透力很强的即时信息服务。其实现原理是客户端发出一个HTTP请求,服务器会将这个http请求放入休眠状 态。由于http协议的特性,一个请求如果没有返回,则这个请求的tcp/ip连接是保持的。 当服务器端有消息的时候,他会激活这个睡眠的线程请求,让其返回。客户端收到这个返回后,会重新发出一个新的请求,用于取出服务器上的消息。然后重复等 待。这个endpoint的形式一般为 /messagebroker/streamingamf
  4. 提供服务器polling的.
    polling也就是我们所说的刷服务器法。 每隔一定的时间间隔,刷新服务器去获取新的消息更新。这个方法跟steaming方式的不同在于,其效率比steaming低,而且他没有steaming提供的消息即时性好。

 

 

服务(Services)

我们看到,一个来自客户端的请求,通过MessageBrokerServlet捕获后,根据请求服务种类,转交给不同服务。

这里有

  1. 远程方法调用服务
    远程方法调用也就是我们最常用的一种服务调用方式,其作用是在Flex客户端调用服务器上的某个方法,取得其返回结果。
  2. 代理服务
    代理服务应该用在某些特殊场合,比如客户端需要调用企业内部的某个服务器上的webservice,而客户端又处于企业防火墙外部,这种情况下,通过 BlazeDS的代理服务,可以让客户端通过BlazeDS服务器(位于企业防火墙之内而又暴露了对外访问的服务器),去访问防火墙内部的某个服务。 另外,当遇到某些服务需要跨域策略文件(crossdomain,xml)的时候,可以通过代理来实现。
  3. 消息服务
    消息服务主要是为Flex客户端提供一个健壮的消息服务接口,你可以通过JMS适配器直接和一些企业级的消息服务器直接连接。

目标(Destination)

目标其实是一个请求的目标:

对于常用的远程方法调用来说,其目标(destination)就是某个特定的java服务,或者某个特定的配置好的Java类

对于代理目标来说,则是定义好的代理种类,比如说普通HTTP代理还是基于WebService的代理

对于消息目标来说,则是某个特定的消息服务种类。

 

适配器(Adapter)

适配器的作用是提供多种实现来提供某种特定的服务

对于远程调用来说,BlazeDS提供了一个默认的JavaAdapter.这个适配器允许你调用服务器上的一个Java类,实际上,还有EJBAdapter,他可以让你的远程调用服务调用一个EJB的方法。

对于代理服务来说,一个不同的适配器意味着你可以访问不同种类的代理资源,这里的例子是基于普通HTTP的代理以及基于SOAP的代理

对于消息服务来说,如果提供JMS适配器,则能让你连接到标准的JMS服务器来交换消息。如果提供一个Actionscript适配器,则可以让你在你的Flex客户端之间交换信息。

 未完待续

riadevID: 
您给予的分值: None 平均分: 8.6 ( 24 票)

BlazeDS 外网访问失败

请教楼主,最近开发的BlazeDS + flex,发现以下问题,请帮忙分析下,谢谢:
最近使用flex + blazeds + struts2开发一套系统,局域网测试都正常,但发布到外网访问测试时,发现httpService连接后台失败,报如下异常:

(mx.messaging.messages::ErrorMessage)#0
body = (null)
clientId = "B6FC04B1-E0D6-150D-B575-0FA029161571"
correlationId = "8FB9E485-15D7-FBB3-3CDD-634F2F328EC0"
destination = "gis.waterRain.getWaterRainStationRainFall"
extendedData = (null)
faultCode = "Server.Proxy.Request.Failed"
faultDetail = "Connection timed out: connect"
faultString = "Error sending request"
headers = (Object)#1
messageId = "B72E0C9E-00D9-817C-4B68-E4206FAA81CF"
rootCause = (null)
timestamp = 1277271381984
timeToLive = 0

谢谢楼主

刚接触flex,正愁要怎么跟数据库联系起来呢,找到路了,谢谢楼主哈

有pring BlazeDS Integration

  1. 有pring BlazeDS Integration 与activemq5.2结合使用jms的介绍吗?
  2. 非常需要!!!

请教楼主 是如何投稿的

我想投稿 基于RIA Flex Flash 平台开发的进销存企业信息管理系统开发经验

谢谢

投稿请发送邮件至下

投稿请发送邮件至下面这个地址的联系方式:http://www.riameeting.com/contact.html
已给您回复,感谢您的来函

楼主继续,期待中啊

楼主继续,期待中啊!!!!!

不错,楼主继续写下

不错,楼主继续写下去呀!

最近有点忙,后面会

最近有点忙,后面会继续写下去的

谢谢

谢谢 对BlazeDS的原理和实现有了一定的了解

发表新评论

  • 网页地址和电子邮件地址将会被自动转换为链接。
  • 行和段被自动切分。
  • 您可以使用下面的标签来高亮显示您的评论内容: <code>, <blockcode>. 可以使用"[foo]".旁边显示标签样式 "<foo>" PHP代码可以用这样的区块来包含<?php ... ?> or <% ... %>

更多格式化选项信息

验证区域
系统验证:请回答下面的问题