新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   >>中国XML论坛<<     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 关于 XML 的一般性技术讨论,提供 XML入门资料 和 XML教程
    [返回] 中文XML论坛 - 专业的XML技术讨论区XML.ORG.CN讨论区 - XML技术『 XML基础 』 → XMLHTTP: 网站超级粘合剂 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 3765 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: XMLHTTP: 网站超级粘合剂 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     admin 帅哥哟,离线,有人找我吗?
      
      
      
      威望:9
      头衔:W3China站长
      等级:计算机硕士学位(管理员)
      文章:5255
      积分:18407
      门派:W3CHINA.ORG
      注册:2003/10/5

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给admin发送一个短消息 把admin加入好友 查看admin的个人资料 搜索admin在『 XML基础 』的所有贴子 点击这里发送电邮给admin  访问admin的主页 引用回复这个贴子 回复这个贴子 查看admin的博客楼主
    发贴心情 XMLHTTP: 网站超级粘合剂

    翻译:Batman
    XML介绍之二十八:XMLHTTP: 网站超级粘合剂
    By Kyle Patrick

    简介
    许多ASP开发者都希望在自己的网站中能够使用到微软提供的支持XML
    的新功能。其中,有些人发现可以使用XML来装饰网站,但是,如果仅仅
    是只使用XMLDOM的话,你就会失去其他一些更重要的东西。毕竟,XML是用来
    作为一种网上数据表现和数据交换的形象出现的。尽管使用XML可以非常满意
    地描绘你的数据,但是开发者却不得不使用CGI来进行浏览器和服务器之间的
    数据交换,除非你在浏览器端和客户端都使用XML文档。
    当然CGI从传达信息的角度来说是能够完全胜任的,但是如果要是和XML来
    一起使用的话就让XML失去了很多自己的用处。幸运的是,微软提供了一种更加
    有效的方法来传输XML,虽然该方法在很大程度上并不被人所重视。
    在微软提供的MSXML解释器包中有一系列的对象,也许没有人会重视其中的
    XMLHTTPConnection对象。简而言之,它允许你打开一个到服务器上的HTTP连接,
    发送一些数据和取回一些数据。并且所有的这一切都是在很少的几段脚本中就能够实现。
    使用XMLHTTP对象通常是进行XML数据交换,但其他格式的数据也是允许的。

    在商业程序中的运用
    这种交换类型的标准模式是客户端发送一个XML格式的文本字符串到服务端,
    然后服务端将这个字符串装载入一个XMLDOM对象中并且解释它,然后返回一段
    HTML给客户端,或则是另外一段XML代码给客户端让客户端的浏览器自己解释。
    在这种方式下,对于信息的传递来说是非常有效的形式,尤其是当你使用
    DHTML允许你根据返回信息动态显示时。
    举例如下(只能够运行在客户端和服务端都安装有IE5的情况下)
    <%
    if (Request.ServerVariables("REQUEST_METHOD") == "POST" )
    {
    var req= Server.CreateObject("Microsoft.XMLDOM");
    req.async=false;
    req.load(Request);
    if (req.documentElement.nodeName=="timesheet")
    {
    //对数据随便进行一些处理。。。
    .....
    Response.write("<h1>Timesheet Updated!</h1><b>"+req.documentElement.text+"</b>");
    }
    }
    else
    { %>

    <div id="divDisplay">The response will be put in here</div>
    <input type="button" onclick="sendData();" value="Send it!">
    <script>
    function sendData(){
    var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
    xmlhttp.Open("POST", "http://www.yoursite.com/thispage.asp", false);
    xmlhttp.Send("<timesheet>An impossibly useless timesheet fragment</timesheet>");
    divDisplay.innerHTML=xmlhttp.responseText;
    }
    </script>
    <% } %>

    在上面的代码中,其中客户端的脚本将建立一个适当的COM对象,打开一个在网站
    www.yoursite.com的连接(使用了HTTP的POST方法,同步方式),使用Send方法发送
    一个XML片段,然后根据服务器上的响应填充divDisplay区域(这里使用了DHTML)。
    具体的执行过程是,在服务器上,Request对象被转载入一个XML文档然后被解释器解释。
    服务器响应XMLHTTP连接的方式和响应其他任何方式的HTTP连接是一样的,也是使用了
    Response对象。注意的是XMLHTTP本身并不检查request或则response的有效性,也就是说
    Request或则Response中的数据可是并不需要一定是XML文档。
    “聪明,”你也许会说。“但是为什么我们不使用CGI来代替它呢?”呵呵,我们要注意
    这样一件事,就是如果使用这种方式进行客户端--服务端的交互时整个页面并没有被刷新。
    我们都知道,如果要是通过CGI来做任何事情都必将导致浏览器接收一个完整的新页面,而
    这尤其影响网站上的访问者,因为他们不得不把所有的时间都用来等候整个页面下载完毕。
    同样,CGI对于网站服务器来说也是一个负担,因为它不得不把宝贵的处理器循环周期和带宽
    消耗在新页面的所有部分。如果这样的操作只是一次或则两次倒无所谓,但是如果是对任何
    一个电子商务网站或则一个基于Web的电子邮件系统,这将意味着大量的同样的基本页面信息
    被重复一次又一次的装载。
    同样,如果是通过CGI在网站运用程序中使用XML,服务端一般都将不得不根据数据来建立
    XML的文档,然后才能够对这些文档进行自己需要的处理。在这种方式下,服务器将花费
    大量的精力在处理如何建构这些XML文档上,尤其是当需要传送的数据量很大时。
    所以如果是让客户端的浏览器来建立这个XML文档,并且在建立完毕后通过XMLHTTP将最后的
    产品传递给服务器,这将大大减轻服务端的代码量和负担。
    这种类型的问题的一个例子是给服务器上的XML文档增加数据。如果是使用CGI的话,那么
    就需要频繁的查询一个CGI的form,然后才能够构建一个加入XML文档的XML节点。而如果是使用
    XMLHTTP需要做的仅仅是把这个XML节点传递给服务端就可以了。

    上面说讨论的是XMLHTTP基本部分,有关它的详细例子你可以在Microsoft Developers
    Network中找到例子 。虽然使用这种通讯方式可以大有作为,我在我自己的运用中仅仅只是
    使用到了很少的一部分,也许任何一个聪明的开发者都能够发现更多的运用事例。

    使用XMLHTTP而不是CGI(即使是我们心爱的ASP)能够让我编写更多野心勃勃的网站运用
    程序,因为现在我们所关心的简单到只是我们需要发送的数据而已。从而使用很少的代码
    就能够实现非常复杂的功能,而CGI对于用户每一个可能的操作都需要我们来完完整整地
    生成一个新的页面。
    但是由于目前并不是所有的浏览器都支持MSXML,许多使用ASP编写的为了非企业内部
    目的的运用程序需要支持CGI的交互。但是欣慰的是,编写一个同时支持CGI和XMLHTTP数据
    的页面并不是很困难,并且将CGI的数据载入XML文档中花费的工作量也不是很大。
    最简单的方式来判断数据是CGI的数据还是XML的数据就是判断数据的MIME类型.
    XMLHTTP的MIME是一个空字符串,除非你特定了其他的MIME类型 (可以到这个连接
    查看不同的MIME类型http://msdn.microsoft.com/xml/reference/scriptref/XMLHttpRequest_object.asp).
    而许多CGI的MIME类型是"application/x-www-form-urlencoded"
    下面就是一个来判断的代码片段:

    <%
    if (Request.ServerVariables("REQUEST_METHOD") == "POST" )
    {
    if (Request.ServerVariables("CONTENT_TYPE")=="application/x-www-form-urlencoded")
    {//如果是常规数据,让CGI来处理
    Response.write(Request.form("stuff"));

    }
    else
    {//如果是XMLHTTP连接,将Request对象转载入XML解释器
    var req= Server.CreateObject("Microsoft.XMLDOM");
    req.resolveExternals=false;
    req.validateOnParse=false;
    req.async=false;
    req.load(Request);
    Response.write(req.documentElement.selectSingleNode("stuff").text);
    }
    }
    else{ %>

    这是一种简单明了的在同一个ASP页面中即可以处理CGI也可以处理XMLHTTP数据的方法。
    并且它也提供了一种能够兼容在客户端安装了IE5.0以及使用其他其他浏览器浏览网站的模式。
    或则也可以采取另外一种方法,就是我对所有的网站运用程序还是采用以前的CGI接口,
    但是在其他类型的客户端运用程序使用XMLHTTP方法,例如Microsoft Office运用程序。
    XMLHTTP的功能并不仅仅局限在浏览器上,我在Microsoft Office的VBA开发程序中使用XMLHTTP
    取得了巨大的成功。现在我假设我被要求使用XML技术在更新我公司服务器上的Excel电子表
    格中的数据。Excel能够将HTML表格直接转载到自己的表格中,但是它不能够处理格式复杂的
    页面,例如本页。数据除非使用了非常巧妙的技巧根本没法插入电子表格。
    我的解决方法是编写了一个ASP页面来操纵通过XMLHTTP从Excel中传递过来的数据。
    通过一个VBA的宏给服务器发送一个请求,然后将响应载入XML文档,通过解释器解释后再
    插入Excel的电子表格中。这将是一个无痕的解决方案,简单的一个按钮也许会让你的老板、
    同事或任何其他人的关系大有改观。
    下面是我实现上述方法的一个代码片段。它使用XMLHTTP将服务器中的信息载入,然后将
    其插入电子表格中。

    Public Sub UpdateSheet()

    Dim xmlhttp
    Set xmlhttp = CreateObject("Microsoft.XMLHTTP")
    Call xmlhttp.Open("POST", "http://www.yourserver.com/yourpage.asp", False)
    Call xmlhttp.send("<reqtimesheet user='jimbob'/>")

    Dim xmldoc
    Set xmldoc = CreateObject("Microsoft.XMLDOM")
    xmldoc.async = False
    xmldoc.loadxml(xmlhttp.responsexml)
    Worksheets("TimeSheet").Range("A1").Value = xmldoc.documentelement.getAttribute("firstname")
    Worksheets("TimeSheet").Range("B1").Value = xmldoc.documentelement.getAttribute("lastname")
    Worksheets("TimeSheet").Range("C37").Value = xmldoc.documentelement.selectSingleNode("totalhours").Text
    End Sub

    这个VBA的宏相当的简单。给服务器发送一个请求,然后将服务器上的响应插入
    XML文档,然后更新Excel中cell中的内容。当然,我们可以使用这个技术做其他更多的运用。
    例如从一个Office运用程序中上载数据到服务器上的XML文档中(XML应该是你首选的格式,
    而不是Office 2000中提供的愚蠢的OfficeXML实现).或则把XML/ASP作为一个你数据库的shell
    这样,你的运用程序对于数据库就有了一个简洁、统一的接口,而对数据库结构的
    改动就不必要改动你所有的客户端代码了。

    我发现XMLHTTP对象在我的编程中非常的有用。我一般使用Visual Basic, Delphi, 和 Visual J++编写程序,在这个过程中,我经常发现这些语言各自对在线程序处理的方法非常地不同,
    他们各自有自己的对网络程序的处理机制,但是如果你要是在处理网络程序时都使用统一
    的XMLHTTP连接方式,那么连接服务器的代码将非常小,甚至更优化,这是一种对所有的
    语言都统一的接口。


       收藏   分享  
    顶(0)
      




    ----------------------------------------------

    -----------------------------------------------

    第十二章第一节《用ROR创建面向资源的服务》
    第十二章第二节《用Restlet创建面向资源的服务》
    第三章《REST式服务有什么不同》
    InfoQ SOA首席编辑胡键评《RESTful Web Services中文版》
    [InfoQ文章]解答有关REST的十点疑惑

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2003/11/18 22:35:00
     
     lgywypb 帅哥哟,离线,有人找我吗?
      
      
      头衔:火星水库总署署长
      等级:大一(高数修炼中)
      文章:24
      积分:102
      注册:2003/11/13

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给lgywypb发送一个短消息 把lgywypb加入好友 查看lgywypb的个人资料 搜索lgywypb在『 XML基础 』的所有贴子 引用回复这个贴子 回复这个贴子 查看lgywypb的博客2
    发贴心情 
    我顶好文章
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2003/11/19 8:26:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 XML基础 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2025/8/14 1:04:32

    本主题贴数2,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    62.012ms