当前位置: 首页 > 图文教程 > 网络编程 > AJAX技术 > 利用Ajax传递Xml文档

AJAX技术
AJAX初体验之实战篇——打造博客无刷新搜索
Ajax按需读取数据生成下级菜单
流行的Ajax应用演示和源码下载
如何使用ajax开发web应用程序
MPBrowser简易图片浏览器 v1.0
Ajax乱码问题整理
asp简单的ajax留言板
健壮的AJAX源码学习应用示例
利用XMLHTTP实现的二级连动Select
AJAX实践DWR篇
AJAX开发者的最新工具和技术
变量冲突处理
ajax技术制作得在线歌词搜索功能
JSP+Ajax 添加、删除多选框
asp简单的ajax留言板(采用三层模式)
ajax发表 读取 评论
ajax.js里面有内容显示效果,根据ID
Ajax 和 Asp 的编程
AJAX应用之草稿自动保存
Ajax loading gif generator

AJAX技术 中的 利用Ajax传递Xml文档


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 72 ::
收藏到网摘: n/a

 
客户端
<script language="javascript">
//生成XML文件 
function GetAllFormData() 

    var strXML = "<Client>\r\n<FormData>\r\n"; 
    strXML += "<UserName>bccu</UserName>"
    strXML += "<Age>25</Age>"; 
    strXML += "</FormData>\r\n</Client>"
    return strXML; 

 
///向服務器发送XML文档 
function Send(Str,URL)  

    var Http = new ActiveXObject("Microsoft.XMLHTTP") 
    Http.open("POST",URL,false) 
    Http.send(Str) 
    return Http.responseText; 

 
///获得XML中指定的节的值 
function GetXMLNodeValue(strXML,nodeName) 

    var Dom = new ActiveXObject("Microsoft.XMLDOM") 
    Dom.async=false  
    Dom.loadXML(strXML) 
    if(Dom.parseError.errorCode != 0)  
    { 
        delete(Dom) 
        return(false) 
    } 
    else 
    { 
        var node = Dom.documentElement.selectSingleNode("//"+nodeName); 
        if(node) 
            nodeValue = node.text; 
        delete(Dom) 
        return(nodeValue); 
    } 

 function Test() 
 { 
    var tmp       = Send(GetAllFormData(),"./test.aspx"); 
    var name      = GetXMLNodeValue(tmp,"UserName"); 
    var password  = GetXMLNodeValue(tmp,"Age"); 
 } 
</script>

服务器端(test.cs)
System.IO.Stream stream = Request.InputStream
System.Xml.XmlDocument doc = new XmlDocument(); 
try 

  doc.Load(stream); //加载发送过来的Xml文档

catch 

  byte[] buffer = new byte[stream.Length]; 
  stream.Read(buffer,0,buffer.Length); 
  string strXML = System.Text.UnicodeEncoding.Default.GetString(buffer,0,buffer.Length); 
  doc.LoadXml(strXML); 

//将doc处理后输出以便返回到客户端(此处省略)

response.write("")