`
xiegangthrille
  • 浏览: 93644 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

Flex与C#的一般处理程序通信

    博客分类:
  • Flex
阅读更多

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# 通讯

    Flex与C#之间的通讯是跨平台应用程序开发中的一个重要主题,特别是在构建富互联网应用程序(RIA)时。本篇文章将深入探讨如何使用Flex与C#(在WinForm环境下)通过Flash Player进行交互,以及在这个过程中涉及的关键...

    Flex Socket与C#通信

    Flex Socket与C#通信是网络编程中的一个常见应用场景,尤其在构建实时交互系统时,如聊天、游戏等。本文将深入探讨如何使用Flex Socket技术在客户端实现与C#服务器端的高效通信,以及相关的实现细节。 Flex是Adobe...

    C#与flex交互

    标题中的"C#与Flex交互"指的是在开发过程中,使用C#作为后端处理逻辑,而Flex作为前端用户界面,两者之间进行数据和功能的通信。Flex是一种基于Adobe AIR和Flash Player运行时的开源框架,主要用于构建富互联网应用...

    FLEX与C#、PHP、JAVA语言通信全面解析

    FLEX作为一款强大的富互联网应用程序(RIA)开发框架,能够与多种后台语言如C#、PHP和JAVA进行通信,实现数据的交换。下面我们将详细解析FLEX与这三种语言通信的方法。 1. **FLEX与C#通信**: 在.NET开发环境中,...

    flex与C# winform交互

    Flex是一种用于创建富...综上所述,Flex与C# WinForm交互涉及到了前端和后端的通信技术,包括Flex的AMF通信、C#的WCF服务以及两者之间的数据交换流程。理解并掌握这些知识点对于构建跨平台的分布式应用程序至关重要。

    Flex用C#和J2EE连接数据库

    在C#环境中,可以利用AMFPHP的C#版本(如Red5Pro)来实现Flex与C#的AMF通信。 3. **BlazeDS**:BlazeDS是Adobe提供的官方解决方案,它为Java服务器提供了AMF支持。虽然J2EE是其主要目标,但通过第三方库(如...

    flex C# 基于socket 通讯 应用程序源码

    在这个项目中,客户端可能是一个使用Flex编写的Web应用程序,它与一个由C#(WinForms)构建的服务端应用程序进行通信。Flex的强项在于其MXML和ActionScript 3.0,用于构建用户界面和处理业务逻辑,而C# WinForms则...

    flex C# 在线拍照

    4. FluorineFx:这是一个开源的.NET Remoting框架,它使得Flex客户端能够与C# Web服务进行通信。在本项目中,FluorineFx可能是Flex和C#服务器之间数据传输的桥梁,允许Flex将捕获的图片数据传送到C#后端。 5. Web ...

    C#与flash通信例子

    在IT领域,C#与Flash之间的通信是一种常见的技术需求,特别是在构建富互联网应用程序(RIA)时。本项目名为"C#与flash通信例子",显然它是一个工程实例,旨在展示如何在C#后端和Flash前端之间实现数据交换。这个工程...

    FluorineFxChatRoom基于Flex和C#的聊天室

    **FluorineFxChatRoom** 是一个使用 **Flex** 和 **C#** 技术构建的聊天室应用,展示了如何结合这两种技术实现一个实时的交互式通信平台。FluorineFx 是一个流行的开源框架,它允许使用 Adobe Flex 客户端与 .NET ...

    FLEX+C#摄像头视频捕捉 自己编写 货真价实

    根据提供的压缩包子文件的文件名,我们可以推测“C#.rar”包含了使用C#编写的代码和可能的库,用于处理摄像头数据、优化解码以及与FLEX的通信。而“FLEX.rar”可能包含AS3代码,这部分代码用于在用户界面上显示...

    [转] flex与c#基于socket的实时互动网络游戏编程教程2

    标题中的“flex与c#基于socket的实时互动网络游戏编程教程2”揭示了本文将深入探讨如何使用Adobe Flex(一种用于创建富互联网应用程序的框架)和C#(一种面向对象的编程语言)通过Socket协议实现实时的网络游戏交互...

    用webservice 连接 flex 加 c#.net

    标题中的“用webservice连接flex加...这个项目示例可以帮助开发者了解Flex与C#.NET之间的集成方式,以及如何通过WebService进行跨平台的数据通信。理解并掌握这一技术,对于开发分布式、跨平台的Web应用具有重要意义。

    C#+Flex 在线聊天

    3. 在Flex中使用Socket类建立与C#服务端的连接,并加载策略文件。 4. 实现客户端事件监听,监听Socket的连接状态、接收数据事件。 5. 用户在客户端输入消息并点击发送,通过Socket将消息发送到服务端。 6. 服务端...

    flex 在线拍照C#源码

    Flex在线拍照C#源码是基于Adobe Flex技术与C#后端开发的一种应用程序,它允许用户在网页上实现在线拍照功能。Flex是一种开源的、基于ActionScript的框架,用于构建富互联网应用程序(RIA)。C#则是一种面向对象的...

    SWF之间通信、Flex与SWF之间通信

    ### SWF之间通信、Flex与SWF之间通信 ...总之,SWF文件之间的通信、Flex与SWF之间的通信以及C#与SWF之间的通信是实现复杂富互联网应用的重要技术手段。掌握这些通信方式可以帮助开发者构建出功能更加强大的应用系统。

    [转] flex与c#基于socket的实时互动网络游戏编程教程一

    标题中的“flex与c#基于socket的实时互动网络游戏编程教程一”揭示了本文档将探讨如何使用Adobe Flex作为前端开发工具,与后端C#服务器通过Socket进行实时通信,实现互动网络游戏的功能。Flex是一款用于创建富互联网...

    Flex与ASP.Net通信(FluorineFx)程序例子

    Flex与ASP.NET之间的通信是构建富互联网应用程序(RIA)时常用的一种技术,它允许前端的Flex界面与后端的ASP.NET服务进行数据交互。在这个程序例子中,我们使用了 FluorineFx 框架来实现这种通信。FluorineFx 是一个...

    Flex与.NET交互

    Flex与.NET交互是一种常见的跨平台应用开发场景,它允许基于Adobe Flex的前端应用程序与Microsoft .NET框架后端服务进行通信。这种交互使得开发者能够利用Flex的富互联网应用(RIA)特性与.NET的强大后端功能相结合...

    C#+FLEX留言版基于Fluorine

    通过FluorineFX,C#服务器端可以直接处理Flex客户端的ActionScript对象,极大地提高了数据通信的效率。 在C#+FLEX留言版的实现中,C#主要负责数据的存储和管理,包括用户登录验证、留言的添加、删除和查询等业务...

Global site tag (gtag.js) - Google Analytics