首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 媒体动画 > flex >

amfphp 与 Flex 通信的两种方式

2012-10-31 
amfphp 与 Flex 通讯的两种方式amfphp是由adobe公司开发的一个开源的项目,用于php与flex通讯的工具类。????

amfphp 与 Flex 通讯的两种方式

amfphp是由adobe公司开发的一个开源的项目,用于php与flex通讯的工具类。

?

?????? amfphp的使用比较简单,只要在官网下载后,解压即可使用,具体的使用方法就不在这里赘述了,要了解

的朋友可以上官网或是下载视频了解(个人推荐 "郑岩峰"关于flex的视频,讲解的比较细).

?

?

这里主要是要讲一下amfphp与php的通讯的两种方法:

1. NetConnection + Responder

2. Remoting Object

?

?

一、NetConnection + Responder 的连接方式

?

1.先定义一个NetConnection变量

2.连接NetConnection

3.调用连接的call方法,以调用服务器上的类及方法。方法是:conn.call("服务器的类.类中的方法",new Responder(处理成功的方法,处理失败的方法,参数1, 参数2,...));

?

如下:

private var conn:NetConnection =? new NetConnection();

?

conn.connect("http://localhost/amfphp/gateway.php");

?

conn.call("HelloWorld.sayHello",new Responder(success,fault),var1,var2....);

?

然后定义成功与失败的方法

?

public funciton success(result:Object):void {

????? //TODo?? //这里的result由于是一个对象,所以可以转换为任意格式,不过也要根据远程服务传回的内容相对应

?

?

}

?

public function fault(result:Object):void {

???? //TODO

}

?

第一种方法就是那么简单。

?

?

二、远程对象 Remoting Object

?

用这个Remoting Object 就比较复杂一些了,不过确是推荐的方法,因为php自4.0以来就支持面向对象的编程了,所以

用远程对象的方法会使传输的数据内容更加丰富,对以后的维护也更加的方便 。

?

1. 先写一个service-config.xml 文件,如果不会写这个文件,在browse下有相应的例子,如下:

?

service-config.xml

?

<?xml version="1.0" encoding="UTF-8"?>
<services-config>
??? <services>
??????? <service id="sabreamf-flashremoting-service"
???????????????? fault="onFault(event)" source="HelloWorld" destination="amfphp">
??? ??? <mx:method name="sayHello"? result="onResult(event)"/>
??? </mx:RemoteObject>

?

在这里定义一个RemoteObject 定义id 为service ,一会使用服务的时候,就要用到这个id.

?

fault 是指当失败时,要调用什么方法,这里的方法要传入一个事件。

source 是指远程的服务的类名

destination 是指我们在 service-config.xml 中定义的关于channel的destination

?

然后在RemoteObject 中定义方法

name 是指远程服务的类下的方法,像我们这里定义 的是HelloWorld 类,这个类下有一个叫sayHello的方法.

result 是指当成功时,要调用哪个方法,这个方法也要传入一个事件

?

如果这个类下有多个方法时,我们可以将所有的方法都写在这里面。

?

?

然后要我们就可以定义一个按钮去触发这个连接了,如下:

?

<mx:TextArea id="amfphptest"? width="200" height="107"/>?

<mx:Button label="call amfphp" click="service.getOperation('sayHello').send(amfphptest.text)" />

?

在这里我们定义了一个文本框 ,用于传入参数及显示服务器中返回的结果。

?

在Button中,当click时,调用我们定义的 RemoteObject的id 即 service

?

service.getOperation('sayHello').send(amfphptest.text)?

?

是指调用 RemoteObject 中的sayHello方法,send是指传送参数,如果有多个参数则用逗号分隔

?

如果RemoteObject中有多个方法时,可以再定义几个按扭以触发这些方法。

?

下面是成功与失败的方法:

?

private function onResult (evt:ResultEvent):void {

??????? amfphptest.text = evt.result.toString();

}

?

private funciton onFault(evt:FaultEvent):void {

??????? amfphptest.text = evt.result.toString();

}

?

可以看来事件的result方法是返回的内容。

?

至些mxml 的内容就是那么多。

?

这里必须要特别注意的一点,必须要确保以下两个步骤正确才能正常运行这个实例

(1). Flex的项目的 Flex Build Path 即是 库中必须引进一个 rpc.swc 包

(2). 在 Flex 项目属性的 Flex Compiler 即是编译选项中的 Additional compiler argments 中加入

????? -locale en_US -service "service-config.xml"? ,即是将我们的destination加入到编译中去。

?

?

上面的实例中,只是返回了字符串,但是我们用的是Remoting Object 即是远程对象,这明显不能

证明Remoting Object的功能的强大,下面我们就定义对象来传递内容的例子做一个说明:

?

?

3. RemotingObject 复杂一点的例子

?

?? (1) 先我们要定义一个as 类

?

?? package bean {

?

?

???????? [RemoteClass(alias="bean.Person")]

???????? [Bindable]

???????? public class Person {

?

??????????????? public var firstName:String;

??????????????? public var lastName:String;

??????????????? public var phone:String;

??????????????? public var email:String;

?

???????? }

?

?

?}

?

?

?? 这里定义了一个类,就是一个实例类,定义为可绑定

?

?? 同时,指定别名,即是远程服务器中的service下也有一个bean文件夹,下面也有一个Person类,

?? 即是表示当前类与服务器中的哪一个类相对应。

?

?

?

?

? (2)创建一个服务端的Person类,我们要在service下的 bean下创建

?

?

??? class Person {

???????? var firstName:String;

???????? var lastName:String;

???????? var phone:String;

???????? var email:String;

?

???????? //explicit actionscript package

???????? var $_explicitType = "bean.Person";

?

?? }

?

??? 这里定义的php的Person 类

??? 可以看到这里除了正常的属性外,还有一个叫$_explicitType属性,

??? 这里就是指定该类与Flex中的哪个类相对应

?

??? 上面两步说明了一点,就是要将两个类进行挂钩。

?

??? 这样,就将两个对象对应起来了,所以就可以将这两个对象进行互传,到时将会由amfphp对其进行自动转换。

?

?

??? (3)定义一个 提供服务的类 PersonService,将其与Person放在同一个目录下

?

?

<?phpinclude("Person.php");class PersonService {            /**       * get a list of perple       * @return an array of person       */      function getList() {          $person = array (                 array("Huang","wenzhou","13512312","123@qq.com");                 array("Yang","Yi","2342234","1233@qq.com");          )                   $p = array();                     for($a=0;$a<count($person);$a++) {                                  $person = new Person();                   $person->firstName = $person[$a][0];                   $person->lastName = $person[$a][1];                   $person->phone = $person[$a][2];                   $person->email = $person[$a][3];                    $p[]=$person;          }                    return $p;     } }?>(4) 定义我们的 mxml 文件     定义RemoteObject        如下    <mx:RemoteObject id="myservice" source="bean.PersonService"             destination="amfphp" fault="faultHandler(event)" showBusyCursor="true">        <mx:method name="getList" result="getListHandler(event)" fault="faultHandler(event)" />    </mx:RemoteObject>     可以看到这里有些许的不同了:     source = bean.PersonService   即是我们的服务层是在bean下的PersonService     destination = amfphp 还是我们之前定义的destination     showBusyCursor = true 是指当我们调用服务时,页面上是否显示正忙的提示。           方法与前面的也差不多。        定义显示数据的DataGrid   <mx:DataGrid x="10" y="10" width="345" id="people_list" dataProvider="{dp}" change="changeHandler(event)">        <mx:columns>            <mx:DataGridColumn headerText="Last name" dataField="lastName"/>            <mx:DataGridColumn headerText="First name" dataField="firstName"/>            <mx:DataGridColumn headerText="Telephone" dataField="phone"/>            <mx:DataGridColumn headerText="Email" dataField="email"/>        </mx:columns>    </mx:DataGrid>   这里要先定义一个 dp,是一个ArrayCollection,这里是要放即一个个的Person    由于之前我们已经将Person.as 与 Person.php 两个对象已经挂钩了,所以这里amfphp会自动将其进行转换。   这里的DataGrid 会有一个change事件, 当用户点击时,将选中的结果显示出来。      这里最后我们看一下我们的成功及失败的方法如何定义。      private function getListHandler(evt:ResultEvent):void {              dp = new ArrayCollection(ArrayUtil.toArray(evt.result));         }   我们再定义我们的 button    <mx:Button x="290" y="357" label="get list" click="myservice.getOperation('getList').send();"/>    复杂的RemoteObject 就完成了。                             

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

?

热点排行