安大互联
财经热点 > Asp编程 > XMLHttpRequest在Web开发利弊
XMLHttpRequest在Web开发利弊
浏览次数:【634】  发布日期:2009-8-13 12:09:22    文章分类:Asp编程   
专题:】 【
 

一、引言

在XMLHttpRequest对象和AJAX给用户和开发者带给巨大好处的同时,也许还有一些问题你没有考量到-可是的确到了值得引起每个人注意的时期了。甚至非常讨厌的人也都喜欢XMLHttpRequest,因为它提供给程序员真正梦想的功能。也正是因为有了这样的新技术,Web应用软件开始变得具有象桌面应用软件相似的表现。如今,问题总是象"假定为……"那样地简单,这把幼稚的终端用户从需要了解服务端、客户、回寄和提交按钮-"提交?提交给什么东西?"-等一大堆问题的苦海中解脱出来。

最近,无数可怕的案例爆炸式出现在Web上,它们充分说明为啥远程脚本(或称"AJAX",假如你喜欢的话)是自从单像素点gif技术以来最伟大的事情。其实,成串的酷极的、有用的应用软件正日益增长,象站点Flickr,Google Maps,The WebORB Presentation Server等所宣传的那样。

这些站点和另外很多地方大举宣传AJAX的能力。公正地说,这种技术在提高在线操作的质量方面的确有十分的潜力来。然而,尽管它有许多的优点,可是这个神圣的Web通讯大杯中嗅起来仍然有一股奇怪的味道;就象摆动在我们面前的啤酒和巧克力,仍有一个邪恶的方面存在于其中-表面上看起来是多么地纯洁和天真。

这种潜在的邪恶存在于用户熟悉的操作界面背后的重要的功能性差距之中。你们当中许多人可能已经使用互联网近十年了,并且你知道它怎样工作:你四处点按鼠标,填充表单,更改你的输入;当做完所有这些,你可以点击提交按钮。你们都了解这些精华经验-它们从因特网的一代传递到新的一代,如:"不要点按提交按钮两次-不然,表单可能要提交两次"或"等待稍微长一些时间,它正在处理"或"在你提交了表单后,不要点按'向后'按钮",...。

可是既然现在AJAX已登堂入室,那么你可以把基本知识抛出窗外。完全是"什么东西都能"-突然间出现一种新的可被跟踪的数据-可以在任何时候发送出去,而不用用户的任何了解,甚至用户还不了解这居 然是可能发生的。每一次击键,每一个鼠标移动,每一下点按鼠标,每一次停顿,都能被抓获并发送到Web服务器,而你对此无能为力。

二、 XMLHttpRequest:利与弊

就象许多技术存在利弊一样,发生这种技术的目标是为了使用其优点。直到如今,XMLHttpRequest带给人们如此多的优点,诸如不需回滚的输入校验,文本区域的拼写检查和Gmail等等,简直几乎为人们捧之为神圣。基于AJAX技术建立的接口使用起来非常有趣,甚至编码更有趣味。简直很难令人相信,这样一种深不可测的技术居 然能够做错事情。

可是,即便还没有发现存在巨大的安全漏洞,该XMLHttpRequest也有可能存在因为其外在的优雅而失败。它很可能会失败在"用户轮廓图"-用于更好的描述之目的-的应用之中。当前,用户轮廓图帮助Web站主侦探趋势,跟踪网页浏览习惯并帮助消除使用性问题。可是直到如今,开发人员还只能分析寄回的数据-用户决定让服务器取得的数据并为提交后得四处理而高兴。

可是通过一种微秒的行径,这种能量平衡会发生易位。通过使用AJAX技术,一个用户的表现可以被持续地并小心地监控。因为它能被做,所以它将被做;这就带给人们一个相当头疼的问题,而不只是浪费带宽、成兆的垃圾信息和更慢的网页装载次数的问题。设想一下,这里仅是举例说明问题,你把一部新购买的iPod掉到地上去了,结果它停止了工作。抱着希望得到免费的替换的思路,你发了一封Email给Apple公司的售后服务部,信中说:"我刚刚买了一个新牌子的iPod。我不小心把它掉到了楼梯上,它突然停止工作了。"之后,你决定删去第贰句以支持你的理由。太晚了!如果该网站使用了AJAX技术,你的反映可能早就被杀死在了你的抱怨桌前!或-一个更恶意破坏性的案例-请考虑这种情景:大多数人都有一个或两个用户名/口令组合以用于他们的"其实不重要"的站点,如新闻站点、博客、论坛等。他们可能还有几个保存的这种组合以用于更敏感的网站-银行业务,Web邮件和工作帐号等。在一个给定页面中输入不正确的登录细节是非常普通和极易犯的错误。虽然他们以前形成的习惯的影响应对此负主要责任,可是在人们点击提交按钮前经常是已经意识到他们所做的事情的。

不幸的是,一个AJAX击键记录程序实现起来相当麻烦。使用如此的一个击键记录程序,就可以用代码来收集不正确的登录尝试,然后针对一系列"重要的"站点对之进行试验-当然,也可以使用XMLHttpRequest对象。

三、 "恶意"暗示

公平地说,上面引用的大多数的"恶意"应用软件都能被合理地加以处理,即便在XMLHttpRequest技术出现以前。的确,request对象是一种相对于以前的IFrame技术更为优雅的成功提交表单数据的要领。可是,XMLHttpRequest以一种更为自然的形式工作,这种方式简直可以能使客户端与服务器端的交互不同逐渐消失。

具有讽刺意味的是,直到不久前,随着Firefox Web浏览器的不断流行,才使得较多用户真正了解到可以由Web客户端贮存和控制的信息的深度和广度。随着广泛采用象Greasemonkey,Web开发者扩展和cookie编辑器这样的工具,人们比以往任何时候更为确信,如果问题发生在客户端,那么责任一般应归咎于该用户。

可是现在,即便象我们这样狂妄的人也不再只是右击鼠标,看一下源代码,而后就能确信正在发生的事情了。请考虑下面的OnReadyStateChange JavaScript语句,运行它是为了响应一个XMLHttpRequest:

xmlReq.onreadystatechange =

{

if( xmlReq.readyState == 4 )

eval( xmlReq.responseText );

}
上面的代码执行包含在来自于XMLHttpRequest的响应中的JavaScript代码。换句话说,有可能发生这种情景:即便一个页面加载完毕,也有可能存在在后台再进行添加或更改JavaScript函数和代码!因此就算你观察该页面代码的源代码-它可能发送了键击或鼠标移动事件到Web服务器,你也无法确信你所见的代码是当前执行的唯一代码。把这些特征与一些令人毛骨悚然的疑惑结合起来,那么你可以看到,恶意目的与XMLHttpRequest对象相结合,咋不能实现Web客户的信息窃取!

四、 还不确信?

你还不感到害怕并因此而愤怒吗?还不准备愤起并删去你的浏览器中的XMLHttpRequest代码吗?那么,好,也许本文强势的措词论证会吓倒了你;那么在游戏"Fonzie寻宝记"(The Search For 's Treasure。译者注:在GOOGLE中输入这几个关键词,你肯定能找到这个在线文本游戏,我没有深入试验。难道这个小东西那么可爱的面孔下居 然埋伏着上面所述的那么恐怖的……)中-你能够救出Fonzie吗?

通过使用很有艺术的命令行接口,穿过布满文本的门厅寻找丢失的Arthur 'Fonzie' Fonzarelli宝藏。祝你幸运,可是请记住…尽管它看上去就象无危害的顾客交互-你每作四次移动,该游戏通过XMLHttpRequest对象发送一个请求到服务器上并保存你的移动。永远记住:不要做一个印刷工(Don't make a typo);不要尝试一些愚蠢的东西如"eat jukebox";不要在游戏中输入一个用户名和口令字;不然……

手机扫码浏览该文章
 ● 相关资讯专题
  • 网络建设业务咨询

   TEl:13626712526