无论您是系统管理员、设计人员还是开发人员,您的工作都会受到 AJAX 的重大影响。管理员必须确保安全防护足够高,以便应对各种可能的新类型攻击。Intranet 管理员则必须保证任何浏览器上都没有禁用 JavaScript。Web 设计人员需要面对一些新的挑战,因为 AJAX 可实现的功能是以前无法实现或不切实际的。而开发人员则需要熟悉新的 API 和新的全面编程方法。尽管如此,AJAX 对架构师来说究竟有何意义?
AJAX 应用程序具有挑战性,因为它们引入了全新的概念和新的基础。AJAX 模式横跨客户端和服务器环境,因此架构师角色必不可少。对于确定客户端上发生的逻辑和处理与服务器上保留的内容,以及确定客户端和服务器上的哪些数据对象能够交换,清晰的体系结构设想显得举足轻重。
AJAX 派上用场
Web 最初用于共享信息的静态页面。短短几年之后,它发展成一种更加动态的媒介。如今,Web 由交互性极强的页面所组成;然而,它仍非常依赖于以整页转换为基础的模式。用户与页面进行的交互越多,必须创建及返回用户浏览器的页面就越频繁。以此方式使用交互式页面所引起的负面结果有很多,例如,减缓页面刷新和闪烁。这是一种不完善的解决方案,经常会导致糟糕的用户体验。AJAX 使得此模式中发生了非常令人渴望的变化,它允许更简洁的 Web 应用程序,并为生成新的应用程序奠定了基础。AJAX 以最终用户为核心。使用 AJAX 功能,Web 应用程序的交互性变得更强,响应更及时,更快速且更友好。交互和响应(操作缓慢时的反馈)都更妥善地得到了处理,便于用户对页面进行更多操作。总之,用户获得了更好的体验。
使用 AJAX,更多代码会在浏览器上执行,这要求将更多脚本指定给客户端页面。但是,这留下了一些大问题有待解决。何种脚本?谁将编写此脚本?此脚本遵循哪些体系结构原则和模式?
在本专栏中,我将从体系结构角度介绍 AJAX,帮助您、开发人员和架构师做出明智选择。同时,我将为设计人员和管理员提供足够的上下文信息,让他们的工作变得更加轻松。这是一个相当大的主题,因此我把它分为两部分来讲。请不要错过下个月的专栏,届时我将继续这一讨论。
AJAX 体系结构
如果您要考虑 AJAX,请看图 1,该图说明了这一步的体系结构含义。传统的 Web 应用程序需要在服务器上执行所有操作,应用程序只是偶尔会发出脚本代码,在客户端上运行任务,如处理数据验证。
图 1传统 Web 模式与 AJAX 模式(单击该图像获得较大视图)
AJAX 应用程序使用负责对 Web 服务器发出调用的客户端框架。AJAX 服务器端框架则负责请求数据馈送并将其返回客户端。这通常是 JavaScript Object Notation (JSON) 数据流,但也可使用其他格式,如 XML、RSS 和 CSV。
客户端接收数据馈送,并使用 JavaScript 更新 UI。该服务器通过返回以指定格式编码的原始数据,对请求做出响应。带宽消耗会降至最低,应用程序速度会提高(因为完成请求所用时间较少),而且 UI 更新也能在无可见回发的情况下生效。但是,在解决众多问题的同时,客户端上操作的增加也带来了新的问题,如新的编码实践、新的安全隐患、可访问性问题等。