zoukankan      html  css  js  c++  java
  • 转:Flash与.NET的通信(二):XML对象的应用

    简介:
        本次测试主要使用Actionscrīpt的XML对象,Flash客户端发送XML(<SendInfo><Value>abc</Value></SendInfo>)给服务器(ASP.NET),服务器将获得<Value>的字符值转化成大写并以XML格式(<ReplayInfo Value='值'/>)回发给Flash客户端。

    主要知识点:
         详细内容见Flash MX Professional 2004帮助文档     
         1.XML.sendAndLoad(url, targetXMLobject
         将指定的 XML 对象编码为 XML 文档,并使用 POST 方法将其发送到指定的 URL,下载服务器的响应,然后将其加载到参数中指定的 targetXMLobject 中。服务器响应的加载方式与 load() 方法使用的方式相同。
         2.XML.onLoad()
         接收到来自服务器的 XML 文档时由 Flash Player 调用。如果成功地收到了 XML 文档,则 success 参数为 true。如果未收到该文档,或在接收来自服务器响应时出现错误,则 success 参数为 false。
    代码及说明:
    Actionscrīpt:
    stop();
    var strXml = "<SendInfo><Value>abc</Value></SendInfo>";
    var sendXml:XML = new XML();//定义发送到服务器的XML对象
    sendXml.ignoreWhite = true;//true时忽略空白
    sendXml.parseXML(strXml);//将XML字符串解释为对象
    var reXml:XML = new XML();//定义接收服务器返回信息的XML对象
    reXml.ignoreWhite = true;
    reXml.onLoad = getReplayInfo;//定义对load和sendAndLoad方法载入数据完成时调用“getReplayInfo”函数
    sendXml.sendAndLoad("你的URL",reXml);
    trace("服务器处理中...");
    function getReplayInfo()
    {
    var getXml:XML = new XML();
    getXml.ignoreWhite = true;
    getXml.parseXML(this);
    if(getXml.firstChild.nodeName == "ReplayInfo")
    {
      trace(getXml.firstChild.attributes.Value);
    }
    else
    {
      trace("服务器错误!");
    }
    }
    ASP.NET
    protected void Page_Load(object sender, EventArgs e)
    {
       Stream xmlStream = Request.InputStream;
       DataSet DS = new DataSet();
       DS.ReadXml(xmlStream);
       XmlDocument xmlDoc = new XmlDocument();
       xmlDoc.LoadXml(DS.GetXml());
       string Value = xmlDoc.SelectSingleNode("SendInfo").ChildNodes[0].InnerText;//节点<Value>的值
       Value = Value.ToUpper();//将值转化成大写
       Response.Write("<ReplayInfo Value='" + Value+ "'/>");
       //回发给客户端Flash
    }
    注:应在ASP.NET的HTML中的页面声明中加入如下信息(红色标注)才能保证页面正确接收XML数据流
    <%@ Page Language="C#" ValidateRequest="false" AutoEventWireup="true" CodeFile="XMLTest.aspx.cs" Inherits="XML_XMLTest" %>测试结果:服务器处理中...
    ABC
  • 相关阅读:
    uitableview 和UISearchBar 下拉提示结合使用
    新浪微博的布局
    ios中键盘处理源码
    JavaScript中十种一步拷贝数组的方法
    小程序图片 mode 设置为 widthFix 图片显示瞬间竖向拉伸变形闪烁
    微信小程序单行和多行省略号
    -webkit-line-clamp 多行文字溢出...
    微信小程序 使用async await
    CSS currentColor 变量的使用
    wn.run万能命令
  • 原文地址:https://www.cnblogs.com/Magicam/p/1273278.html
Copyright © 2011-2022 走看看