Flex与.NET互操作(八) 使用FluorineFx网关实现远程访问

于此,本文将使用FluorineFx网关来提供数据服务等多项功能来介绍通过FluorineFx实现远程访问的相关知识点。

FluorineFx提供的远程访问包括有很多方面的知道点,本文只介绍其中的三个知识点:访问远程对象返回对象,返回DataTable,返回DataSet对象.FluorineFx安装包里自带有相关的示例程序,要学习更多可直接参考这些示例程序.

在实现访问前我们同样来做一些准备工作,建立好远程对象,如下:

1 namespace Fluorine.ServiceLibrary
 2 {
 3     public class Book
 4     {
 5         public int Id { get; set; }
 6         public string Name { get; set; }
 7         public string Author { get; set; }
 8         public double Price { get; set; }
 9     }
10 }

下面是提供Flex访问的远程对象:

Code
 1 namespace Fluorine.ServiceLibrary
 2 {
 3     [RemotingService]
 4     public class FluorineService
 5     {
 6         /// <summary>
 7         /// 返回一个简单对象
 8         /// </summary>
 9         /// <returns></returns>
10         public Book GetBook()
11         {
12             return new Book
13             {
14                 Id = 1,
15                 Name = "《三国演义》",
16                 Author = "罗贯中",
17                 Price = 100
18             };
19         }
20 
21         /// <summary>
22         /// 返回DataTable对象
23         /// </summary>
24         /// <returns></returns>
25         [DataTableType("Fluorine.ServiceLibrary.Book")]
26         public DataTable GetDataTable()
27         {
28             DataTable dt = new DataTable("Book");
29             dt.Columns.Add("Id", typeof(int));
30             dt.Columns.Add("Name", typeof(string));
31             dt.Columns.Add("Author", typeof(string));
32             dt.Columns.Add("Price", typeof(double));
33 
34             DataRow dr = dt.NewRow();
35             dr["Id"] = 1;
36             dr["Name"] = "《三国演义》";
37             dr["Author"] = "罗贯中";
38             dr["Price"] = 52.30;
39             dt.Rows.Add(dr);
40 
41             dr = dt.NewRow();
42             dr["Id"] = 2;
43             dr["Name"] = "《西游记》";
44             dr["Author"] = "吴承恩";
45             dr["Price"] = 39.91;
46             dt.Rows.Add(dr);
47 
48             return dt;
49         }
50 
51         /// <summary>
52         /// 返回DataSet对象
53         /// </summary>
54         /// <returns></returns>
55         [DataSetType("Fluorine.ServiceLibrary.Book")]
56         public DataSet GetDataSet()
57         {
58             DataSet ds = new DataSet("DS");
59             DataTable dt = ds.Tables.Add("Books");
60             dt.Columns.Add("Id", typeof(int));
61             dt.Columns.Add("Name", typeof(string));
62             dt.Columns.Add("Author", typeof(string));
63             dt.Columns.Add("Price", typeof(double));
64 
65             DataRow dr = dt.NewRow();
66             dr["Id"] = 1;
67             dr["Name"] = "《三国演义》";
68             dr["Author"] = "罗贯中";
69             dr["Price"] = 52.30;
70             dt.Rows.Add(dr);
71 
72             dr = dt.NewRow();
73             dr["Id"] = 2;
74             dr["Name"] = "《西游记》";
75             dr["Author"] = "吴承恩";
76             dr["Price"] = 39.91;
77             dt.Rows.Add(dr);
78 
79             return ds;
80         }
81 
82     }
83 }

上面代码片段中分别提供了返回一个对象,DataTable,DataSet对象的方法。这里只需要记住两个关键标识就行,它门是:DataTableType和DataSetType.  下面通过Flex的非可视化组件<mx:RemoteObject>来访问远程对象,OK,下面我们来看看具体怎么来调用。

1 <mx:RemoteObject id="ro" destination="fluorine" >
2     source="Fluorine.ServiceLibrary.FluorineService"
3     fault="onFaultHandler(event)"
4     <mx:method name="GetBook" result="onGetBookHandler(event)"/>
5     <mx:method name="GetDataTable" result="onGetDataTableHandler(event)"/>
6     <mx:method name="GetDataSet" result="onGetDataSetHandler(event)"/>
7 </mx:RemoteObject>

一、返回对象示例

1 [Binable]
2 private var book:BookVO;
3     
4 private function onGetBookHandler(evt:ResultEvent):void
5 {
6     book=evt.result as BookVO;
7 }

通过点击按扭调用远程方法GetBook()完成方法的调用,直接可以将返回结果绑定到界面元素上。

1 <mx:Button label="Book" click="ro.GetBook()"/>
2 <mx:TextInput width="302" text="{boo.Name+book.Author+book.Price}"/>

二、返回DataTable对象

返回DataTable和DataSet,将结果绑定到DataGrid上显示,先看看DataGrid的定义:

1 <mx:DataGrid x="10" y="10" width="543" height="147" dataProvider="{books}">
2     <mx:columns>
3             <mx:DataGridColumn headerText="编号" dataField="Id"/>
4             <mx:DataGridColumn headerText="书名" dataField="Name"/>
5             <mx:DataGridColumn headerText="作者" dataField="Author"/>
6             <mx:DataGridColumn headerText="价格" dataField="Price"/>
7     </mx:columns>
8 </mx:DataGrid>

DataGrid的数据源为定义的一个ArrayCollection对象,详细如下:

1 [Binable]
2 private var books:ArrayCollection;

1 private function onGetDataTableHandler(evt:ResultEvent):void
2 {
3     books=evt.result as ArrayCollection;
4 }

 三、返回DataTable对象

1 private function onGetDataSetHandler(evt:ResultEvent):void
2 {
3     books=evt.result as ArrayCollection;
4 }

如上便完成了通过FluorineFx网关来实现远程访问,下面是完整的Flex端代码,实现很简单这里就不作详细讲解:

1 <?xml version="1.0" encoding="utf-8"?>
 2 <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute">
 3     <mx:Script>
 4         <![CDATA[
 5             import mx.controls.Alert;
 6             import mx.rpc.events.ResultEvent;
 7             import mx.rpc.events.FaultEvent;
 8             import mx.collections.ArrayCollection;
 9             [Binable]
10             private var books:ArrayCollection;
11             [Binable]
12             private var book:BookVO;
13             
14             private function onGetBookHandler(evt:ResultEvent):void
15             {
16                 book=evt.result as BookVO;
17             }
18             
19             private function onGetDataTableHandler(evt:ResultEvent):void
20             {
21                 books=evt.result as ArrayCollection;
22             }
23             
24             private function onGetDataSetHandler(evt:ResultEvent):void
25             {
26                 books=evt.result as ArrayCollection;
27             }
28             
29             private function onFaultHandler(evt:FaultEvent):void
30             {
31                 Alert.show(evt.fault.faultDetail);
32             }
33         ]]>
34     </mx:Script>
35     <mx:Panel x="42" y="56" width="578" height="226" layout="absolute" fontSize="12">
36     <mx:DataGrid x="10" y="10" width="543" height="147" dataProvider="{books}">
37         <mx:columns>
38                 <mx:DataGridColumn headerText="编号" dataField="Id"/>
39                 <mx:DataGridColumn headerText="书名" dataField="Name"/>
40                 <mx:DataGridColumn headerText="作者" dataField="Author"/>
41                 <mx:DataGridColumn headerText="价格" dataField="Price"/>
42         </mx:columns>
43     </mx:DataGrid>
44     <mx:ControlBar>
45         <mx:Button label="DataTable" click="getDataTable()"/>
46         <mx:Button label="DataSet" click="getDataSet()"/>
47         <mx:Button label="Book" click="ro.GetBook()"/>
48         <mx:TextInput width="302" text="{boo.Name+book.Author+book.Price}"/>
49     </mx:ControlBar>
50     </mx:Panel>
51     <mx:RemoteObject id="ro" destination="fluorine" >
52         source="Fluorine.ServiceLibrary.FluorineService"
53         fault="onFaultHandler(event)"
54         <mx:method name="GetBook" result="onGetBookHandler(event)"/>
55         <mx:method name="GetDataTable" result="onGetDataTableHandler(event)"/>
56         <mx:method name="GetDataSet" result="onGetDataSetHandler(event)"/>
57     </mx:RemoteObject>
58 </mx:Application>
="COLOR: rgb(0,128,128)">19             private function onGetDataTableHandler(evt:ResultEvent):void
20             {
21                 books=evt.result as ArrayCollection;
22             }
23             
24             private function onGetDataSetHandler(evt:ResultEvent):void
25             {
26                 books=evt.result as ArrayCollection;
27             }
28             
29             private function onFaultHandler(evt:FaultEvent):void
30             {
31                 Alert.show(evt.fault.faultDetail);
32             }
33         ]]>
34     </mx:Script>
35     <mx:Panel x="42" y="56" width="578" height="226" layout="absolute" fontSize="12">
36     <mx:DataGrid x="10" y="10" width="543" height="147" dataProvider="{books}">
37         <mx:columns>
38                 <mx:DataGridColumn headerText="编号" dataField="Id"/>
39                 <mx:DataGridColumn headerText="书名" dataField="Name"/>
40                 <mx:DataGridColumn headerText="作者" dataField="Author"/>
41                 <mx:DataGridColumn headerText="价格" dataField="Price"/>
42         </mx:columns>
43     </mx:DataGrid>
44     <mx:ControlBar>
45         <mx:Button label="DataTable" click="getDataTable()"/>
46         <mx:Button label="DataSet" click="getDataSet()"/>
47         <mx:Button label="Book" click="ro.GetBook()"/>
48         <mx:TextInput width="302" text="{boo.Name+book.Author+book.Price}"/>
49     </mx:ControlBar>
50     </mx:Panel>
51     <mx:RemoteObject id="ro" destination="fluorine" >
52         source="Fluorine.ServiceLibrary.FluorineService"
53         fault="onFaultHandler(event)"
54         <mx:method name="GetBook" result="onGetBookHandler(event)"/>
55         <mx:method name="GetDataTable" result="onGetDataTableHandler(event)"/>
56         <mx:method name="GetDataSet" result="onGetDataSetHandler(event)"/>
57     </mx:RemoteObject>
58 </mx:Application>

(0)

相关推荐

  • Flex与.NET互操作(八) 使用FluorineFx网关实现远程访问

    于此,本文将使用FluorineFx网关来提供数据服务等多项功能来介绍通过FluorineFx实现远程访问的相关知识点. FluorineFx提供的远程访问包括有很多方面的知道点,本文只介绍其中的三个知识点:访问远程对象返回对象,返回DataTable,返回DataSet对象.FluorineFx安装包里自带有相关的示例程序,要学习更多可直接参考这些示例程序. 在实现访问前我们同样来做一些准备工作,建立好远程对象,如下: 1 namespace Fluorine.ServiceLibrary 2

  • Flex与.NET互操作(十三):FluorineFx.Net实现视频录制与视频回放

    通过它我们可以非常方便的实现在线视频录制.视频直播.视频聊天以及视频会议等类似应用程序的开发. 在<FMS3系列(四):在线视频录制.视频回放 >这篇文章里我写了通过FMS来实现在线视频录制和视频回放的功能,客户端的开发和这篇文章是相同的,不同的是本文将使用Flex来开发. 首先我们来看看使用FluorineFx服务端是如何开发的,建立ApplicationAdapter是必然的,这里我们为本文中的示例程序建立的ApplicationAdapter为VideoApplication,并为其添加

  • Flex与.NET互操作(十一):FluorineFx.Net的及时通信应用(Remote Procedure Call)(二)

    NET的服务器端同样也可以非常方便的呼叫客户端,调用客户端的方法(比如实现系统广播). 一.客户端的RPC(客户端调用服务器端) 要想实现客户端访问服务器端的方法,首先得对ActionScript中的NetConnection比较熟悉,该类提供了一个示例方法call()专们用来做RPC访问,该方法的定义如下: public function call(command:String, responder:Responder,  arguments):void 比如说我们在开发一个及时应用的时候,所

  • Flex与.NET互操作(十):FluorineFx.Net的及时通信应用(ApplicationAdapter)(一)

    应用程序适配器对象也就相当于是一个Flash媒体服务器应用程序的对象. 使用FluorineFx.Net开发及时通信应用,我们可以通过ASP.NET网站来宿主,一个ASP.NET网站可以承载多个实时通讯应用程序.这些应用程序都存储ASP.NET网站的根目录下指定文件夹的根目录中.如下图示: 在开发FluorineFx的及时通信应用的时候,按照FluorineFx的目录结构配置ASP.NET的站点目录是非常简单的,只需要在ASP.NET站点下面建立一个名为apps的目录,那么FluorineFx就

  • Flex和.NET协同开发利器FluorineFx Flex与.NET互操作

    通过这些方式来完成与服务端的通信是非常方便和简单的,但有他的缺点就是通信数据量较小,如要传输大量的数据或是实现不同对象的序列化传输,它们则满足不了我们的需求,需要寻找另外一种通信协议,另一种高效的传输协议来代替SOAP协议传输的方案,那便是AMF(ActionScript Message Format)协议. 开源项目FluorineFx就是专门针对.NET平台与Flex通信提供的AMF协议通信网关,我们可以通过FluorineFx很方便的完成与.NET的通信. FluorineFx官方提供了安

  • Flex与.NET互操作(十二):FluorineFx.Net的及时通信应用(Remote Shared Objects)(三)

    FluorineFx所提供的远程共享对象(Remote Shared Objects)和FMS的共享对象的功能是一样,对于熟悉FMS开发的朋友来说,学习FluorineFx的远程共享对象是非常简单的. 共享对象可以在服务器端创建,也可以在客户端创建.在客户端创建共享对象的方法和使用FMS开发是一样的,创建一个 NetConnection对象,通过该对象的connect()方法连接到服务器,然后通过SharedObject.getRemote()方法就可以在客户端创建一个远程共享对象.如下实例代码

  • FluorineFx.NET的认证(Authentication )与授权(Authorization)Flex与.NET互操作 九

    应用程序可根据用户信息授予和拒绝执行.FluorineFx.NET的认证和授权使用.Net Framework基于角色的安全性的支持. 比如说我们需要自定义一个认证与授权的方案,指定那些远程服务上的那些方法将要被认证或授权以及授权用户角色组等,我们就需要自定义一个 LoginCommand并实现ILoginCommand接口或者继承于 FluorineFx.Security.GenericLoginCommand(此类实现了ILoginCommand接口)基类.接口定义如下: 1 namespa

  • Flex与.NET互操作 了解FluorineFx的环境配置(远程对象、网关、通道、目的地)

    在本系列文章的前面几篇文章中所介绍的访问Webservice的方法,也就是一种远程对象方法,只不过他是基于WEB服务(WebServie)的远程访问,不是基于远程对象(Remoting Object)的的远程访问.要想直接实现基于对象的远程访问是比较麻烦的,然后FluorineFx则专门为我们提供了该功能,通过 FluorineFx的核心库来开发远程对象(Remoting Object)服务,具体是怎么实现的呢? FluorineFx要求为远程对象提供[RemotingService]标记来提供

  • Flex与.NET互操作 使用HttpService、URLReqeust和URLLoader加载/传输数据

    ActionScript 3.0中提供的数据加载请求类主要是HTTPService,URLLoader和URLRequest,可以通过他们协同来完成数据加载和请求.下面我么便来看看这三个类是怎么来完成数据加载工作. 在本地IIS服务器上有如下定义的XML文件: 1 <?xml version="1.0" encoding="utf-8" ?> 2 <Root> 3   <Book> 4     <Id>1</Id

  • Flex与.NET互操作 使用FileReference+HttpHandler实现文件上传/下载

    在Flex的应用开发中,同ASP.NET,JSP,PHP等应用一样,都会有上传/下载文件的应用需求,Flex的SDK也为我们提供了专门的类 FileRefUdderence实现文件上传/下载.Flex只是作为一个客户端,要实现上传或下载必须得为其提供一个服务端来接受上传或下载的请求,本文以ASP.NET中的HttpHandler作为文件上传的服务端来完成上传功能. OK,我们从Flex客户端开始,看看客户端是通过什么方式想服务端发起请求.Flex客户端要完成文件上传下载都是通过FileRefUd

随机推荐