请慎用Ajax请求来探测不存在的资源

80酷酷网    80kuku.com

  ajax|请求

    不知道各位有几个还记得Apress的《Foundations.of.Ajax》中描述的HEAD请求的pattern?

是的,你可以利用XHR向一个你并不知道在与不在的资源发送请求,从而探测期的存在,做出相应的判断处理。其实发送任何GET请求也可以,只不过一般认为HEAD请求比较轻量级,比较容易使用而已。

但实际上是这样子吗?

案例

    在技术上我是比较激进的一派,还保持着热血青年的特性。所以,在当时新需求到来时,为了印证新技术的可行性,我冒险采用了XHR的HEAD方式。

    需求是这样的:

    我们需要及时探知远程服务器的状态,从而做到在服务器状态发生变化时(比如,机器刚刚启动起来),通知客户端的用户。

    在以前,这样的需求你是无法用Web实现的。顶多你用一个Web服务器上的服务端程序去探知,然后发送给Web客户端。但是,Ajax的到来让这个变为可能。通过领会Ajax的思想,我们果断的设计了一种方案,用JavaScript在客户端建立了一个应用程序,发送XHR请求来探知远端服务器的状态,完成相应的操作。

    可以说,这样一个设计深谙Ajax的精髓。XHR的进入,让传统的B/S程序有向C/S演变的趋势。该设计迎合这种趋势,结合需求,实现了这种功能。

问题

    随着测试的进行,问题接踵而至。

    其实,在刚开始设计此系统时并不是没有做探索性研究。由于Ajax本身就是一项新技术,即便是其是新瓶装旧酒,但由于项目之前没有采用过,任何人都不会贸然采用。

    不过,由于研究匆忙,测试时并没有覆盖到所有的case,导致问题的产生。

    当该设计应用到实际的项目中去后,随着测试的开展,逐渐发现了问题。

    首先,在mozilla 1.2.1环境下发现该程序毫无相应。主要表现为该程序其他功能都可以运行,唯独XHR探测远程资源的功能无法使用。为啥呢?

    经过调查,发现问题是这样的。

    Mozilla低版本浏览器确实支持XHR,而且之前我们也有成功的经验。可问题是Mozilla低版本浏览器对XHR的支持在请求不存在资源时有些特殊,具体表现如下。

       当请求不成功时,mozilla 1.2.1得请求顺序如下:

1、READY_STATE_LOADING=1;

2、READY_STATE_LOADING=1;

3、READY_STATE_LOADED=2;

之后就销声匿迹了。

相反,我们的程序一直在等待READY_STATE_COMPLETE=4;的状态,所以程序从此失去相应。

从逻辑上讲,我们不可以依赖READY_STATE_LOADED状态。因为在正常时,READY_STATE_LOADED也是有可能出现的。所以,对Mozilla低版本浏览器中所存在的这种问题,我们没有太好的办法,唯一的办法就是自己设置超时机制。

之后,随着测试的深入,又发现了问题。

仅仅以firefox 1.5.0.4为例来讲,其用XHR探测远端不存在资源的流程也是不一样的。我们发现,win下的firefox工作正常,而linux下的firefox工作起来非常缓慢。经过测试,我们发现在linux下的firefox环境中,如果要向一个远端不存在资源发送一个请求,其大约要400秒左右才会有返回,而同样的操作在win版的firefox上却只要几十秒而已。

仅仅时间上长短的不同,就让我们的应用方案面目皆非。

如果说mozilla低版本浏览器由于时间较早,其错误处理流程有问题还情有可原。但是,同样版本的firefox在不同的平台下表现迥异就让人太不理解了。不过没办法,项目要求必须兼容不同平台的浏览器,也必须兼容mozilla,所以。。。。。。

顺带替一句,IE的XHR无论何种操作均表现正常,可以依赖。而开源新贵seamonkey的表现同他的老大哥firefox一样,平台差异很大。

当然,有些程序只要求在某某平台,某某浏览器上实现,那另说。

总结

    第一个吃螃蟹的总是会面临风险。成功了,人人歌颂;失败了,尽管沮丧,但是我们也不能放弃一次学习的机会。

    总结如下:

依赖于不变的因素,切莫依赖于变化。在进行OOD时,我们通常会谈到两个原则,即开闭原则和Liskov原则。其实这两个原则结合起来,就是强调,要面向接口变成。因为接口一般来说都是不变的,而内部的实现是经常变化的。在这里,我们虽然不是OOD,但是也有一些变与不变的因素。一般来讲,人们在实现一个通用的功能时,都会将成功的一面做的特别好,比较一致,而将错误处理个性化起来,特别是一个新生事物,成功的一面通过大家的使用,都会统一起来,而错误处理由于较少有人碰到,结果导致形态各异。在具体进行设计时,一定要对以来的条件因素进行区分,慎选。如果依赖于一些变化快速的因素,将导致设计失败。特别考虑那些易变的部分,比如错误处理,在前期研究时就要投入更多精力。前期研究时,也应当特别考虑极端情况,从而提高研究的价值,降低风险。

 

 



分享到
  • 微信分享
  • 新浪微博
  • QQ好友
  • QQ空间
点击: