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