flex和后端的数据交互(一)--XML和HTTPService(最常用的哦)
最近学习
flex,参考了不少网上的资料,特别是 中国
flex开发者(http://www.flexer.cn/)。
flex数据交互是一个关键,做个学习总结,请
flex老鸟指正!
flex和后端的数据交互有很多方式, flex可以使用ActionScript读写文件(xml、txt)的形式存储显示数据,
在 Flex 3.0中新增了对本地数据库(.db格式)操作的类,可用于读取本地的数据库数据。新增了对PDF数据
操作的类,可用于读取PDF数据。
xml文件方式
XML优点是简单小巧、存储方便、检索快速。所以,XML常用于数据存储和数据交换。 Flex 3.使用URLLoader类可方便地传输XML数据。
使用XML方式传输数据的步骤如下所示。
新建名为"tree.xml"文件,用以存储XML数据:
xml文件的读写我们可以用FileStream类来实现:
读取xml文件:
写回xml文件
需要说明一下的是文件打开方式:FileMode
READ --设置文件打开方式为只读
WRITE--设置文件打开方式为写数据。文件不存在,则创建;文件存在,则覆盖原有数据。
APPEND--设置文件打开方式为追加。文件不存在,则创建;文件存在,则新数据从文件末尾开始增加。
UPDATE--设置文件打开方式为读写。文件不存在,则创建。设置该模式通常用于随机读写访问文件。可以从文件的任意位置读取,写入数据时,只有写入位置的存在字节被覆盖,其他所有字节不受影响。
这里我们使用URLRequest类来加载xml数据,编写应用程序初始化处理函数loadXML。
变量,用以指明XML文件路径。
public function loadXML():void//应用程序初始化处理函数
{
//定义URLRequest实例,指定文件地址。
var request:URLRequest=new URLRequest("tree.xml");
loader.load(request);//加载XML文件
loader.addEventListener(Event.COMPLETE,completeHandle); //添加加载完成时的监听
}
loader.addEventListener(Event.COMPLETE,completeHandle)语句表示添加对XML加载完成事件的监听。一旦加载完成执行
completeHandle函数。完成剩余MXML代码。剩余代码包括completeHandle函数,<mx:Tree>组件设计等。
以下代码是完整的MXML代码。
这是运行结果截图:
<mx:HTTPService>组件方式
<mx: HTTPService>组件可与所有的后端程序交互。例如,ASP、ASP.Net、JSP、PHP等。
以下是一个<mx: HTTPService>组件语法示例:
<mx: HTTPService id="feedRequest" url="http://localhost:8080/myflex/helloworld?para_1=para_1¶_2=para_2" result="showResult(event)" />
id唯一标识该组件,url是数据提交的地址,可以在地址后面添加参数,提交到后端进行处理,处理后
再返回 Flex可识别的数据类型,如数组型、XML型、Object型等。
<mx: HTTPService>组件返回的数据存储于ResultEvent类中。使用<mx: HTTPService>组件的result事件可处理HTTP程序返回的数据。
eg. <mx: HTTPService result="处理函数名">
返回的数据存储于ResultEvent类的result属性下。各种数据的具体位置与HTTP程序的处理结果有关。
数据返回后的处理方法示例:
来一个简单的例子会让你更加明白的!
这是客户端mxml的源代码:
"http://localhost:8080/myflex/sum"是一个servlet的映射地址,actionscript方法addHandle将每一个数字参数添加到url映射地
址后面并且向服务器发送请求,addData方法把输入的数字显示到下方列表,delData方法删除整个列表,httpHandle方法处理服务器
的返回值。其中e.result.sumTag表示取得xml返回数据中sumTag标签中的内容。
以下是servlet中对接收参数的处理:
下面是例子运行的截图:
下一次学习总结一下<mx:WebService>组件和RemoteObject及其他的交互方式!
flex和后端的数据交互有很多方式, flex可以使用ActionScript读写文件(xml、txt)的形式存储显示数据,
在 Flex 3.0中新增了对本地数据库(.db格式)操作的类,可用于读取本地的数据库数据。新增了对PDF数据
操作的类,可用于读取PDF数据。
xml文件方式
XML优点是简单小巧、存储方便、检索快速。所以,XML常用于数据存储和数据交换。 Flex 3.使用URLLoader类可方便地传输XML数据。
使用XML方式传输数据的步骤如下所示。
新建名为"tree.xml"文件,用以存储XML数据:
- <?xml version="1.0" encoding="utf-8"?>
- <menus>
- <node label="Mail">
- <node label="Inbox"/>
- <node label="Personal Folder">
- <node label="Demo"/>
- <node label="Personal"/>
- <node label="Saved Mail"/>
- <node label="bar"/>
- </node>
- <node label="Calendar"/>
- <node label="Sent"/>
- <node label="Trash"/>
- </node>
- </menus>
<?xml version="1.0" encoding="utf-8"?> <menus> <node label="Mail"> <node label="Inbox"/> <node label="Personal Folder"> <node label="Demo"/> <node label="Personal"/> <node label="Saved Mail"/> <node label="bar"/> </node> <node label="Calendar"/> <node label="Sent"/> <node label="Trash"/> </node> </menus>
xml文件的读写我们可以用FileStream类来实现:
读取xml文件:
- var testXML:XML;
- var file:File = File.documentsDirectory.resolvePath("tree.xml");
- var fileStream:FileStream = new FileStream();
- fileStream.open(file, FileMode.READ);
- testXML = XML(fileStream.readUTFBytes(fileStream.bytesAvailable));
- fileStream.close();
var testXML:XML; var file:File = File.documentsDirectory.resolvePath("tree.xml"); var fileStream:FileStream = new FileStream(); fileStream.open(file, FileMode.READ); testXML = XML(fileStream.readUTFBytes(fileStream.bytesAvailable)); fileStream.close();
写回xml文件
- var testXML:XML=<content>content</content>......;
- var file:File = File.documentsDirectory.resolvePath("tree.xml");
- var fileStream:FileStream = new FileStream();
- fileStream.open(file, FileMode.WRITE);
- var outputString:String = '<?xml version="1.0" encoding="utf-8"?>\n';
- outputString += testXML.toXMLString();
- fileStream.writeUTFBytes(outputString);
- fileStream.close();
var testXML:XML=<content>content</content>......; var file:File = File.documentsDirectory.resolvePath("tree.xml"); var fileStream:FileStream = new FileStream(); fileStream.open(file, FileMode.WRITE); var outputString:String = '<?xml version="1.0" encoding="utf-8"?>\n'; outputString += testXML.toXMLString(); fileStream.writeUTFBytes(outputString); fileStream.close();
需要说明一下的是文件打开方式:FileMode
READ --设置文件打开方式为只读
WRITE--设置文件打开方式为写数据。文件不存在,则创建;文件存在,则覆盖原有数据。
APPEND--设置文件打开方式为追加。文件不存在,则创建;文件存在,则新数据从文件末尾开始增加。
UPDATE--设置文件打开方式为读写。文件不存在,则创建。设置该模式通常用于随机读写访问文件。可以从文件的任意位置读取,写入数据时,只有写入位置的存在字节被覆盖,其他所有字节不受影响。
这里我们使用URLRequest类来加载xml数据,编写应用程序初始化处理函数loadXML。
变量,用以指明XML文件路径。
public function loadXML():void//应用程序初始化处理函数
{
//定义URLRequest实例,指定文件地址。
var request:URLRequest=new URLRequest("tree.xml");
loader.load(request);//加载XML文件
loader.addEventListener(Event.COMPLETE,completeHandle); //添加加载完成时的监听
}
loader.addEventListener(Event.COMPLETE,completeHandle)语句表示添加对XML加载完成事件的监听。一旦加载完成执行
completeHandle函数。完成剩余MXML代码。剩余代码包括completeHandle函数,<mx:Tree>组件设计等。
以下代码是完整的MXML代码。
- <?xml version="1.0" encoding="utf-8"?>
- <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" fontFamily="simsun"
- fontSize="12" layout="absolute" width="242" height="442" creationComplete="loadXML()">
- <mx:Script>
- <![CDATA[
- import mx.collections.ArrayCollection;
- import mx.rpc.events.ResultEvent;
- public var loader:URLLoader=new URLLoader();
- public var menus:XML=new XML();
- public function loadXML():void
- {
- var request:URLRequest=new URLRequest("tree.xml");
- loader.load(request);
- loader.addEventListener(Event.COMPLETE,completeHandle);
- }
- public function completeHandle(e:Event):void
- {
- menus=XML(loader.data);
- var results:XMLList=menus.node;
- tree.dataProvider=results;
- }
- ]]>
- </mx:Script>
- <mx:Tree id="tree" x="10" y="35" width="218" height="397" labelField="@label" />
- <mx:Label x="10" y="10" text="Tree Nodes From XML File"/>
- </mx:Application>
<?xml version="1.0" encoding="utf-8"?> <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" fontFamily="simsun" fontSize="12" layout="absolute" width="242" height="442" creationComplete="loadXML()"> <mx:Script> <![CDATA[ import mx.collections.ArrayCollection; import mx.rpc.events.ResultEvent; public var loader:URLLoader=new URLLoader(); public var menus:XML=new XML(); public function loadXML():void { var request:URLRequest=new URLRequest("tree.xml"); loader.load(request); loader.addEventListener(Event.COMPLETE,completeHandle); } public function completeHandle(e:Event):void { menus=XML(loader.data); var results:XMLList=menus.node; tree.dataProvider=results; } ]]> </mx:Script> <mx:Tree id="tree" x="10" y="35" width="218" height="397" labelField="@label" /> <mx:Label x="10" y="10" text="Tree Nodes From XML File"/> </mx:Application>
这是运行结果截图:
<mx:HTTPService>组件方式
<mx: HTTPService>组件可与所有的后端程序交互。例如,ASP、ASP.Net、JSP、PHP等。
以下是一个<mx: HTTPService>组件语法示例:
<mx: HTTPService id="feedRequest" url="http://localhost:8080/myflex/helloworld?para_1=para_1¶_2=para_2" result="showResult(event)" />
id唯一标识该组件,url是数据提交的地址,可以在地址后面添加参数,提交到后端进行处理,处理后
再返回 Flex可识别的数据类型,如数组型、XML型、Object型等。
<mx: HTTPService>组件返回的数据存储于ResultEvent类中。使用<mx: HTTPService>组件的result事件可处理HTTP程序返回的数据。
eg. <mx: HTTPService result="处理函数名">
返回的数据存储于ResultEvent类的result属性下。各种数据的具体位置与HTTP程序的处理结果有关。
数据返回后的处理方法示例:
- import mx.rpc.events.ResultEvent;
- import mx.controls.Alert;
- private function showResult(e:ResultEvent):void
- {
- Alert.show(e.result as String);
- }
import mx.rpc.events.ResultEvent; import mx.controls.Alert; private function showResult(e:ResultEvent):void { Alert.show(e.result as String); }
来一个简单的例子会让你更加明白的!
这是客户端mxml的源代码:
- <?xml version="1.0" encoding="utf-8"?>
- <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" >
- <mx:Script>
- <![CDATA[
- import mx.rpc.events.ResultEvent;
- import mx.controls.Alert;
- private var arr:Array=new Array();
- private function addHandle():void
- {
- myHttp.url="http://localhost:8080/myflex/sum";
- if(arr.length>0)
- myHttp.url+="?";
- for(var i:int=0;i<arr.length;i++)
- {
- if(i!=arr.length-1)
- myHttp.url+="num="+arr[i].para.toString()+"&";
- else
- myHttp.url+="num="+arr[i].para.toString();
- }
- Alert.show(myHttp.url);
- myHttp.send();
- }
- private function addData():void
- {
- var obj:Object=new Object();
- obj.para=txtPara.text;
- arr.push(obj);
- dg.dataProvider=arr;
- txtPara.text="";
- dg.validateNow();
- }
- private function delData():void
- {
- arr=new Array();
- dg.dataProvider=arr;
- dg.validateNow();
- }
- private function httpHandle(e:ResultEvent):void
- {
- lblResult.text=e.result.sumTag;
- }
- ]]>
- </mx:Script>
- <mx:HTTPService id="myHttp" showBusyCursor="true" result="httpHandle(event);" useProxy="false"/>
- <mx:Panel title="测试HTTPService" width="368" height="334" x="78" y="30" layout="absolute">
- <mx:Label text="叠加参数:" x="110" y="26"/>
- <mx:TextInput id="txtPara" x="161" y="24" width="95"/>
- <mx:DataGrid id="dg" x="76" y="64" height="166" width="179">
- <mx:columns>
- <mx:DataGridColumn dataField="para" headerText="参数列表"/>
- </mx:columns>
- </mx:DataGrid>
- <mx:Button label="添加" click="addData();" x="277" y="26"/>
- <mx:Button label="删除" click="delData();" x="277" y="64"/>
- <mx:Label text="叠加结果是:" x="58" y="253"/>
- <mx:Label x="126" y="253" id="lblResult"/>
- <mx:Button label="计算" click="addHandle();" x="277" y="249"/>
- </mx:Panel>
- </mx:Application>
<?xml version="1.0" encoding="utf-8"?> <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" > <mx:Script> <![CDATA[ import mx.rpc.events.ResultEvent; import mx.controls.Alert; private var arr:Array=new Array(); private function addHandle():void { myHttp.url="http://localhost:8080/myflex/sum"; if(arr.length>0) myHttp.url+="?"; for(var i:int=0;i<arr.length;i++) { if(i!=arr.length-1) myHttp.url+="num="+arr[i].para.toString()+"&"; else myHttp.url+="num="+arr[i].para.toString(); } Alert.show(myHttp.url); myHttp.send(); } private function addData():void { var obj:Object=new Object(); obj.para=txtPara.text; arr.push(obj); dg.dataProvider=arr; txtPara.text=""; dg.validateNow(); } private function delData():void { arr=new Array(); dg.dataProvider=arr; dg.validateNow(); } private function httpHandle(e:ResultEvent):void { lblResult.text=e.result.sumTag; } ]]> </mx:Script> <mx:HTTPService id="myHttp" showBusyCursor="true" result="httpHandle(event);" useProxy="false"/> <mx:Panel title="测试HTTPService" width="368" height="334" x="78" y="30" layout="absolute"> <mx:Label text="叠加参数:" x="110" y="26"/> <mx:TextInput id="txtPara" x="161" y="24" width="95"/> <mx:DataGrid id="dg" x="76" y="64" height="166" width="179"> <mx:columns> <mx:DataGridColumn dataField="para" headerText="参数列表"/> </mx:columns> </mx:DataGrid> <mx:Button label="添加" click="addData();" x="277" y="26"/> <mx:Button label="删除" click="delData();" x="277" y="64"/> <mx:Label text="叠加结果是:" x="58" y="253"/> <mx:Label x="126" y="253" id="lblResult"/> <mx:Button label="计算" click="addHandle();" x="277" y="249"/> </mx:Panel> </mx:Application>
"http://localhost:8080/myflex/sum"是一个servlet的映射地址,actionscript方法addHandle将每一个数字参数添加到url映射地
址后面并且向服务器发送请求,addData方法把输入的数字显示到下方列表,delData方法删除整个列表,httpHandle方法处理服务器
的返回值。其中e.result.sumTag表示取得xml返回数据中sumTag标签中的内容。
以下是servlet中对接收参数的处理:
- public void doPost(HttpServletRequest request, HttpServletResponse response)
- throws ServletException, IOException
- {
- String[] para = request.getParameterValues("num");
- int sum = 0;
- if (para != null)
- {
- for (int i = 0; i < para.length; i++)
- {
- if (para[i] != null && !"".equals(para[i]))
- {
- sum = sum + Integer.parseInt(para[i]);
- }
- }
- }
- response.getWriter().print(
- "<?xml version=\"1.0\" encoding=\"utf-8\"?><sumTag>" + sum
- + "</sumTag>");
- }
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String[] para = request.getParameterValues("num"); int sum = 0; if (para != null) { for (int i = 0; i < para.length; i++) { if (para[i] != null && !"".equals(para[i])) { sum = sum + Integer.parseInt(para[i]); } } } response.getWriter().print( "<?xml version=\"1.0\" encoding=\"utf-8\"?><sumTag>" + sum + "</sumTag>"); }
下面是例子运行的截图:
下一次学习总结一下<mx:WebService>组件和RemoteObject及其他的交互方式!