一起谈.NET技术,Flex 数据访问 WebService (上)

简介:   Flex 支持格式设置为 SOAP 消息且通过 HTTP 传输的 Web 服务请求和结果。SOAP 提供基于 XML 格式的定义,用于在 Web 服务客户端(如使用 Flex 构建的应用程序)和 Web 服务之间交换结构化和类型化信息。

  Flex 支持格式设置为 SOAP 消息且通过 HTTP 传输的 Web 服务请求和结果。SOAP 提供基于 XML 格式的定义,用于在 Web 服务客户端(如使用 Flex 构建的应用程序)和 Web 服务之间交换结构化和类型化信息。

  在.NET和Flex的数据交互可以通过Web Services访问string,object,datatable,List<>,ArrayList等。

  .NET和Flex的数据示例:

  1、返回对象

  定义返回对象的Web Method:

 
 
[WebMethod]
public Employee GetEmployee()
{
return new Employee
{
id
= 1 ,
name
= " Shawn " ,
age
= 25
};
}

  Flex前端代码:

 
 
<? 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.FaultEvent;
import mx.rpc.events.ResultEvent;
import mx.controls.Alert;
private function onResult(event:ResultEvent):void
{
Alert.show(event.result.name);
}

private function onFault(event:FaultEvent):void
{
Alert.show("调+event.message);
}

private function GetEmployee():void
{
this.MyService.GetEmployee.send();
}
]]>
</ mx:Script >
< mx:Button label ="Get Employee" click ="GetEmployee()" />

< mx:WebService id ="MyService" wsdl ="http://localhost:4081Flex.asmx?WSDL" useProxy ="false" result ="onResult(event)" fault ="onFault(event)" >
< mx:operation name ="GetEmployee" />
</ mx:WebService >
</ mx:Application >

  运行结果:

image

  2、返回DataTable

  定义返回DataTable的Web Method:

 
  
[WebMethod]
public DataTable GetDataTable()
{
DataTable dt
= new DataTable( " Employees " );
dt.Columns.Add(
" id " , typeof ( int ));
dt.Columns.Add(
" name " , typeof ( string ));
dt.Columns.Add(
" age " , typeof ( int ));

DataRow dr
= dt.NewRow();
dr[
" id " ] = 1 ;
dr[
" name " ] = " Shawn " ;
dr[
" age " ] = 25 ;
dt.Rows.Add(dr);

dr
= dt.NewRow();
dr[
" id " ] = 2 ;
dr[
" name " ] = " Jack " ;
dr[
" age " ] = 23 ;
dt.Rows.Add(dr);

return dt;
}

  Flex前端代码:

 
  
<? 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.FaultEvent;
import mx.rpc.events.ResultEvent;
import mx.controls.Alert;
private function onResult(event:ResultEvent):void
{
}
private function onFault(event:FaultEvent):void
{
Alert.show("调+event.message);
}
private function GetDataTable():void
{
this.MyService.GetDataTable.send();
}
]]>
</ mx:Script >
< mx:Panel width ="400" >
< mx:DataGrid id ="gvEmployee" dataProvider ="{this.MyService.GetDataTable.lastResult.Tables.Employees.Rows}" width ="100%" >
< mx:columns >
< mx:DataGridColumn headerText ="ID" dataField ="id" />
< mx:DataGridColumn headerText ="Name" dataField ="name" />
< mx:DataGridColumn headerText ="Age" dataField ="age" />
</ mx:columns >
</ mx:DataGrid >
< mx:ControlBar >
< mx:Button label ="Get DataTable" click ="GetDataTable()" />
</ mx:ControlBar >
</ mx:Panel >
< mx:WebService id ="MyService" wsdl ="http://localhost:4081/Flex.asmx?WSDL" useProxy ="false" result ="onResult(event)" fault ="onFault(event)" >
< mx:operation name ="GetDataTable" />
</ mx:WebService >
</ mx:Application >  

  运行结果:

image

  3、返回List<>

 
  
[WebMethod]
public List < Employee > GetEmployeeList()
{
return new List < Employee >
{
new Employee
{
id
= 1 ,
name
= " Shawn " ,
age
= 25
},
new Employee
{
id
= 2 ,
name
= " Jack " ,
age
= 23
}
};
}

  Flex前端:

 
  
<? xml version="1.0" encoding="utf-8" ?>
< mx:Application xmlns:mx ="http://www.adobe.com/2006/mxml" layout ="absolute" >
< mx:Script >
<![CDATA[
import mx.collections.ArrayCollection;
import mx.rpc.events.FaultEvent;
import mx.rpc.events.ResultEvent;
import mx.controls.Alert;
private function onResult(event:ResultEvent):void
{
var arr:ArrayCollection = this.MyService.GetEmployeeList.lastResult as ArrayCollection;
gvEmployee.dataProvider=arr;
}

private function onFault(event:FaultEvent):void
{
Alert.show("调+event.message);
}

private function GetEmployeeList():void
{
this.MyService.GetEmployeeList.send();
}
]]>
</ mx:Script >

< mx:Panel width ="400" >
< mx:DataGrid id ="gvEmployee" width ="100%" >
< mx:columns >
< mx:DataGridColumn headerText ="ID" dataField ="id" />
< mx:DataGridColumn headerText ="Name" dataField ="name" />
< mx:DataGridColumn headerText ="Age" dataField ="age" />
</ mx:columns >
</ mx:DataGrid >
< mx:ControlBar >
< mx:Button label ="Get List" click ="GetEmployeeList()" />
</ mx:ControlBar >
</ mx:Panel >
< mx:WebService id ="MyService" wsdl ="http://localhost:4081/Flex.asmx?WSDL" useProxy ="false" result ="onResult(event)" fault ="onFault(event)" >
< mx:operation name ="GetEmployeeList" />
</ mx:WebService >
</ mx:Application >

  运行结果: image

目录
相关文章
mvc.net分页查询案例——DLL数据访问层(HouseDLL.cs)
mvc.net分页查询案例——DLL数据访问层(HouseDLL.cs)
|
网络协议 定位技术 网络安全
IPIP.NET-IP地理位置数据
IPIP.NET 是一家专注于 IP 地理位置数据的提供商,基于 BGP/ASN 数据与全球 800+ 网络监测点技术,提供高精度的 IPv4 和 IPv6 定位服务。其核心服务包括地理位置查询、详细地理信息和网络工具等,广泛应用于网络安全、广告营销、CDN 优化等领域。数据覆盖全球,支持多语言,每日更新确保实时性。IPIP.NET 提供 API 接口、离线数据库及多种语言 SDK,方便开发者集成使用。
2727 0
|
SQL XML 关系型数据库
入门指南:利用NHibernate简化.NET应用程序的数据访问
【10月更文挑战第13天】NHibernate是一个面向.NET的开源对象关系映射(ORM)工具,它提供了从数据库表到应用程序中的对象之间的映射。通过使用NHibernate,开发者可以专注于业务逻辑和领域模型的设计,而无需直接编写复杂的SQL语句来处理数据持久化问题。NHibernate支持多种数据库,并且具有高度的灵活性和可扩展性。
496 2
|
SQL 存储 关系型数据库
C#一分钟浅谈:使用 ADO.NET 进行数据库访问
【9月更文挑战第3天】在.NET开发中,与数据库交互至关重要。ADO.NET是Microsoft提供的用于访问关系型数据库的类库,包含连接数据库、执行SQL命令等功能。本文从基础入手,介绍如何使用ADO.NET进行数据库访问,并提供示例代码,同时讨论常见问题及其解决方案,如连接字符串错误、SQL注入风险和资源泄露等,帮助开发者更好地利用ADO.NET提升应用的安全性和稳定性。
869 6
【Azure Key Vault】.NET 代码如何访问中国区的Key Vault中的机密信息(Get/Set Secret)
【Azure Key Vault】.NET 代码如何访问中国区的Key Vault中的机密信息(Get/Set Secret)
205 3
|
算法 Java 测试技术
java 访问ingress https报错javax.net.ssl.SSLHandshakeException: Received fatal alert: protocol_version
java 访问ingress https报错javax.net.ssl.SSLHandshakeException: Received fatal alert: protocol_version
2448 1
|
开发框架 .NET 数据库连接
闲话 Asp.Net Core 数据校验(三)EF Core 集成 FluentValidation 校验数据例子
闲话 Asp.Net Core 数据校验(三)EF Core 集成 FluentValidation 校验数据例子
295 1
|
开发框架 前端开发 JavaScript
基于SqlSugar的数据库访问处理的封装,支持.net FrameWork和.net core的项目调用
基于SqlSugar的数据库访问处理的封装,支持.net FrameWork和.net core的项目调用
|
开发框架 缓存 NoSQL
基于SqlSugar的数据库访问处理的封装,在.net6框架的Web API上开发应用
基于SqlSugar的数据库访问处理的封装,在.net6框架的Web API上开发应用