加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Flex与服务器交互

发布时间:2020-12-15 04:39:21 所属栏目:百科 来源:网络整理
导读:Flex与后端服务器的交互,主要有3种方式: LCDS、Http Service、Web Service 1.?LifeCycle Data Services,这个是Adobe的组件,是以一个war包的形式存在,所以它只能跟JAVA整合,并且它是需要钱买的,大概10W。它是通过调用远程对象的方式来访问我们的后端服

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=zhaoql&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> 默认情况,Flex中ResultEvent的result类型不支持JSON格式的数据,

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

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

??????????????? 错误:{username:’zhaoql’,password:523}

?????????????? 正确:{“username”:”zhaoql”,“password”:523}

3.?Web Service

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读