二、 Flex与服务器交互

Flex与后端服务器的交互,主要有3种方式: LCDS、Http Service、Web Service

1.     LifeCycle Data Services,这个是Adobe的组件,是以一个war包的形式存在,所以它只能跟JAVA整合,并且它是需要钱买的,大概10W。它是通过调用远程对象的方式来访问我们的后端服务的,所以一般情况下,如果使用LCDS,就直接访问我们的Service业务层,而不需要通过Struts层,它使用Flex自带的协议,比HTTP协议要快。

<mx:RemoteObject id="">

    <mx:method name="addUser">

        <mx:arguments>

           <username></username>

        </mx:arguments>

    </mx:method>

</mx:RemoteObject>

2.     Http Service,即通过HTTP协议访问后端服务,像普通jsp页面访问后端服务一样,先访问Struts,再由Struts来调用我们的Service层。调用代码如下:

(1)引入Http Service组件:

<mx:HTTPService id="myAdd" url="http://localhost:8088/MyFlex/addUser.action" method="POST" result="myResponse(event)">

     <!--请求的参数:如:username=name&password=123456 -->

     <mx:request>

        <username>{this.username.text}</username>

        <password>{this.password.text}</password>

     </mx:request>

</mx:HTTPService>

(2)发送请求

private function doAddUser():void

{

     this.myHttpService.send();

}

(3)接收服务器返回的数据

private function myResponse(event:ResultEvent):void

{

     // result就是服务器端返回的结果

     Alert(event.result);

}

 注意:a> 默认情况,FlexResultEventresult类型不支持JSON格式的数据,

b> 我们可以下载第三方的包:as3corelib,然后将as3corelib.awc放到flex_libs目录,

c> 然后使用JSON.decode(event.result);就可以返回一个JSON对象,
      d>
但是在服务端返回的JSON字符串,有一个要求:不能使用单引号,而只能使用双引号,包括属性名称也必须要用双引号引起来,否则JSON类会解析不了或者出错,例如:

错误{username:’name’, password:523}

正确{“username”:”name”, “password”:523}

3. Web Service

posted on 2010-01-10 22:13  TroyZ  阅读(1469)  评论(0编辑  收藏  举报