Flex代码:
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute"
backgroundColor="0x414141">
<!--上面preload属性与下面外部CSS可以删除它
preloader="com.preload.PreLoad"
<mx:Style source="yfskin/yflexskin.css"/>
-->
<mx:Script>
<![CDATA[
import mx.collections.ArrayCollection;
import flash.events.Event;
import mx.rpc.events.ResultEvent;
import mx.controls.Alert;
import mx.events.CloseEvent;
import com.adobe.serialization.json.JSON;
private function personJSON(event:ResultEvent):void
{
//get the raw JSON data and cast to String
var rawData:String = String(event.result);
//showMsg(rawData);
var person = JSON.decode(rawData);
txtName.text = person.data[0].name;
txtGx.text = person.data[0].sex;
txtAddress.text = person.data[0].age;
txtNiceName.text = person.data[0].email;
txtEmployees.text = "不是";
var persons:Array = person.data as Array;
var personsCollection:ArrayCollection = new ArrayCollection(persons);
dg.dataProvider = personsCollection;
}
private function showMsg(obj:String):void
{
var alert:Alert = Alert.show(
obj,"Alert Window Title",
Alert.OK|Alert.CANCEL|Alert.NO|Alert.YES,
this);
}
private function managerJSON(event:ResultEvent):void
{
//获取原始JSON数据并输出到InputText控件上
var rawData:String = String(event.result);
var alert:Alert = Alert.show(
rawData,"Alert Window Title",
Alert.OK|Alert.CANCEL|Alert.NO|Alert.YES,
this);
var manager = JSON.decode(rawData);
txtName.text = manager.txt_name;
txtGx.text = manager.txt_gx;
txtAddress.text = manager.address;
txtNiceName.text = manager.nice_name;
txtEmployees.text = "是";
//更新DataGrid
var employees:Array = manager.employees as Array;
var employeesCollection:ArrayCollection = new ArrayCollection(employees);
dg.dataProvider = employeesCollection;
}
private function onSelected():void
{
txtName.text = dg.selectedItem.txt_name;
txtGx.text = dg.selectedItem.txt_gx;
txtAddress.text = dg.selectedItem.address;
txtNiceName.text = "";
txtEmployees.text = "";
}
]]>
</mx:Script>
<mx:HTTPService id="personRequest" url="http://localhost:5401/WebFlex/HandlerFlex.ashx"
showBusyCursor="true" useProxy="false" method="GET" resultFormat="text"
result="personJSON(event)" >
<mx:request xmlns="">
<data>"true"</data>
</mx:request>
</mx:HTTPService>
<mx:HTTPService id="managerRequest" url="http://localhost:5401/WebFlex/HandlerFlex.ashx"
showBusyCursor="true" useProxy="false" method="GET" resultFormat="text"
result="managerJSON(event)">
<mx:request xmlns="">
<getManager>"true"</getManager>
</mx:request>
</mx:HTTPService>
<mx:Panel x="0" y="0" width="730" height="240"
layout="absolute" title="JSON 数据源实例">
<mx:DataGrid id="dg" x="210" y="10" width="505" rowCount="5"
rowHeight="25" enabled="true" editable="false" change="onSelected()">
<mx:columns>
<mx:DataGridColumn headerText="姓名" dataField="name"/>
<mx:DataGridColumn headerText="性别" dataField="sex"/>
<mx:DataGridColumn headerText="年龄" dataField="age"/>
<mx:DataGridColumn headerText="邮箱" dataField="email"/>
</mx:columns>
</mx:DataGrid>
<mx:Label x="10" y="12" text="姓名:"/>
<mx:TextInput id="txtName" x="50" y="11" width="150" editable="false"/>
<mx:Label x="10" y="41" text="关系:"/>
<mx:TextInput id="txtGx" x="50" y="40" width="150" editable="false"/>
<mx:Label x="10" y="74" text="住址:"/>
<mx:TextInput id="txtAddress" x="50" y="72" width="150" editable="false"/>
<mx:Label x="10" y="105" text="昵称:"/>
<mx:TextInput id="txtNiceName" x="50" y="103" width="150" editable="false"/>
<mx:Label x="10" y="136" text="屋主:"/>
<mx:TextInput id="txtEmployees" x="50" y="134" width="150"
editable="false" text="不是"/>
<mx:Button id="getPerson" x="270" y="165" label="侄女"
click="personRequest.send();"/>
<mx:Button id="getManager" x="380" y="165" label="我的家族"
click="managerRequest.send();"/>
</mx:Panel>
</mx:Application>
C#代码:
<%@ WebHandler Language="C#" Class="HandlerFlex" %>
using System;
using System.Web;
using System.Net;
using System.Text;
using System.Threading;
public class HandlerFlex : IHttpHandler {
private HttpContext con;
public void ProcessRequest (HttpContext context) {
context.Response.ContentType = "text/plain";
//context.Response.Write("Hello World");
con = context;
this.Start();
}
public void Start()
{
Thread t = new Thread(new ThreadStart(ListenRequest));
t.Start();
}
private void ListenRequest()
{
HttpResponse response = con.Response;
string msg = this.getJsonData();
con.Response.Write(msg);
}
private string getJsonData()
{
StringBuilder jsonData = new StringBuilder();
jsonData.Append("{\"data\":[{\"name\":\"谢刚\",\"sex\":\"男\",\"age\":\"21\",\"email\":\"xiegangthrille@126.com\"}]}");
//jsonData.Append("{\"nice_name\":\"\u963f\u5065\",\"employees\":[{\"txt_name\":\"\u963f\u96ea\",\"txt_gx\":\"\u8001\u5a46\",\"email\":\"xuelove520@21cn.com\",\"address\":\"\u5e7f\u4e1c\u8087\u5e86\u5e7f\u5b81\u8c2d\u5e03\u6c34\u58f0\u5cad\"},{\"txt_name\":\"\u5b87B\",\"txt_gx\":\"\u513f\u5b50\",\"email\":\"0758yu@163.com\",\"address\":\"\u5730\u7403\u4e9a\u6d32\u4e2d\u56fd\u5e7f\u4e1c\u8087\u5e86\u5e7f\u5b81\u5357\u8857\"}],\"txt_name\":\"\u6b27\u5b97\u5065\",\"txt_gx\":\"\u67f1\u4eba\",\"email\":\"0758jian@163.com\",\"address\":\"\u592a\u9633\u7cfb\u7ecf\u706b\u661f\u5230\u5730\u7403\"}");
return jsonData.ToString();
}
public void RespClient(HttpListenerResponse response, string msg)
{
try
{
byte[] buffer = Encoding.UTF8.GetBytes(msg);
response.ContentType = @"text/xml";
response.ContentLength64 = buffer.Length;
System.IO.Stream output = response.OutputStream;
output.Write(buffer, 0, buffer.Length);
output.Close();
}
catch (Exception e)
{
}
}
public bool IsReusable {
get {
return false;
}
}
}
flex工程需要用到的库:http://code.google.com/p/as3corelib/downloads/list
分享到:
相关推荐
Flex与C#之间的通讯是跨平台应用程序开发中的一个重要主题,特别是在构建富互联网应用程序(RIA)时。本篇文章将深入探讨如何使用Flex与C#(在WinForm环境下)通过Flash Player进行交互,以及在这个过程中涉及的关键...
Flex Socket与C#通信是网络编程中的一个常见应用场景,尤其在构建实时交互系统时,如聊天、游戏等。本文将深入探讨如何使用Flex Socket技术在客户端实现与C#服务器端的高效通信,以及相关的实现细节。 Flex是Adobe...
标题中的"C#与Flex交互"指的是在开发过程中,使用C#作为后端处理逻辑,而Flex作为前端用户界面,两者之间进行数据和功能的通信。Flex是一种基于Adobe AIR和Flash Player运行时的开源框架,主要用于构建富互联网应用...
FLEX作为一款强大的富互联网应用程序(RIA)开发框架,能够与多种后台语言如C#、PHP和JAVA进行通信,实现数据的交换。下面我们将详细解析FLEX与这三种语言通信的方法。 1. **FLEX与C#通信**: 在.NET开发环境中,...
Flex是一种用于创建富...综上所述,Flex与C# WinForm交互涉及到了前端和后端的通信技术,包括Flex的AMF通信、C#的WCF服务以及两者之间的数据交换流程。理解并掌握这些知识点对于构建跨平台的分布式应用程序至关重要。
在C#环境中,可以利用AMFPHP的C#版本(如Red5Pro)来实现Flex与C#的AMF通信。 3. **BlazeDS**:BlazeDS是Adobe提供的官方解决方案,它为Java服务器提供了AMF支持。虽然J2EE是其主要目标,但通过第三方库(如...
在这个项目中,客户端可能是一个使用Flex编写的Web应用程序,它与一个由C#(WinForms)构建的服务端应用程序进行通信。Flex的强项在于其MXML和ActionScript 3.0,用于构建用户界面和处理业务逻辑,而C# WinForms则...
4. FluorineFx:这是一个开源的.NET Remoting框架,它使得Flex客户端能够与C# Web服务进行通信。在本项目中,FluorineFx可能是Flex和C#服务器之间数据传输的桥梁,允许Flex将捕获的图片数据传送到C#后端。 5. Web ...
在IT领域,C#与Flash之间的通信是一种常见的技术需求,特别是在构建富互联网应用程序(RIA)时。本项目名为"C#与flash通信例子",显然它是一个工程实例,旨在展示如何在C#后端和Flash前端之间实现数据交换。这个工程...
**FluorineFxChatRoom** 是一个使用 **Flex** 和 **C#** 技术构建的聊天室应用,展示了如何结合这两种技术实现一个实时的交互式通信平台。FluorineFx 是一个流行的开源框架,它允许使用 Adobe Flex 客户端与 .NET ...
根据提供的压缩包子文件的文件名,我们可以推测“C#.rar”包含了使用C#编写的代码和可能的库,用于处理摄像头数据、优化解码以及与FLEX的通信。而“FLEX.rar”可能包含AS3代码,这部分代码用于在用户界面上显示...
标题中的“flex与c#基于socket的实时互动网络游戏编程教程2”揭示了本文将深入探讨如何使用Adobe Flex(一种用于创建富互联网应用程序的框架)和C#(一种面向对象的编程语言)通过Socket协议实现实时的网络游戏交互...
标题中的“用webservice连接flex加...这个项目示例可以帮助开发者了解Flex与C#.NET之间的集成方式,以及如何通过WebService进行跨平台的数据通信。理解并掌握这一技术,对于开发分布式、跨平台的Web应用具有重要意义。
3. 在Flex中使用Socket类建立与C#服务端的连接,并加载策略文件。 4. 实现客户端事件监听,监听Socket的连接状态、接收数据事件。 5. 用户在客户端输入消息并点击发送,通过Socket将消息发送到服务端。 6. 服务端...
Flex在线拍照C#源码是基于Adobe Flex技术与C#后端开发的一种应用程序,它允许用户在网页上实现在线拍照功能。Flex是一种开源的、基于ActionScript的框架,用于构建富互联网应用程序(RIA)。C#则是一种面向对象的...
### SWF之间通信、Flex与SWF之间通信 ...总之,SWF文件之间的通信、Flex与SWF之间的通信以及C#与SWF之间的通信是实现复杂富互联网应用的重要技术手段。掌握这些通信方式可以帮助开发者构建出功能更加强大的应用系统。
标题中的“flex与c#基于socket的实时互动网络游戏编程教程一”揭示了本文档将探讨如何使用Adobe Flex作为前端开发工具,与后端C#服务器通过Socket进行实时通信,实现互动网络游戏的功能。Flex是一款用于创建富互联网...
Flex与ASP.NET之间的通信是构建富互联网应用程序(RIA)时常用的一种技术,它允许前端的Flex界面与后端的ASP.NET服务进行数据交互。在这个程序例子中,我们使用了 FluorineFx 框架来实现这种通信。FluorineFx 是一个...
Flex与.NET交互是一种常见的跨平台应用开发场景,它允许基于Adobe Flex的前端应用程序与Microsoft .NET框架后端服务进行通信。这种交互使得开发者能够利用Flex的富互联网应用(RIA)特性与.NET的强大后端功能相结合...
通过FluorineFX,C#服务器端可以直接处理Flex客户端的ActionScript对象,极大地提高了数据通信的效率。 在C#+FLEX留言版的实现中,C#主要负责数据的存储和管理,包括用户登录验证、留言的添加、删除和查询等业务...