反向Ajax的基本概念是客户端不必从服务器获取信息,服务器会把相关信息直接推送到客户端。这样做的目的是解决Ajax传统模型所到来的限制,实时信息很难从技术上解决。原因是客户端必须联系服务器,主动询问是否存在变更,如果有变更就会更新页面。虽然可以非常快速王城这个操作,我们需要的是服务器联系查看其页面的所有浏览器,并通告所发生的变更。
反向Ajax是哭胡这个限制的一种方式。像Ajax本身一样,这不是一门专门的技术,而是按照不寻常方式组合使用已有的技术达到不寻常的效果。现在总共有三种DWR支持的技术可以辅助完成这种技术,其中两种技术都属于“主动的”反向Ajax,第三种被认为是“被动的”反向Ajax。
1.轮询:
假设有个未使用Ajax的web页面,使用<Meta>刷新标签,每隔数秒就更新这个页面。这就是所说的轮询,客户端定时轮询服务器,看是否存在更新,并且显示服务器传回的当前信息。在网页上,使用一些简单的JavaScript代码以持续地更新页面,就可以实现相同的事情。确实能够从表面实现所谓的推送,这个就是轮询技术。
在Ajax中,事件流会更加复杂,但是实质上是一样的,轮询技术是两个主动反向Ajax方法中的一种,客户端在每个时间周期内向服务器发送请求,看看服务器端有没有数据更新,如果有,就像服务器请求数据。
2.服务器推:
第二种主动式反向Ajax方法是Comet,这时一种基于HTTP长连接的服务器推动方式。客户端向服务器发送请求后,服务器将数据通过response发送给客户端,但并不会将response关闭,而是一直通过response将最新的数据发送给客户端浏览器,知道客户端浏览器关闭。使用Ajax实现“服务器推”与传统的AJAX应用不同之处在于:
1.服务器端会阻塞请求知道有数据传递或超时才返回。
2.客户端JavaScript响应处理函数会在处理完服务器返回的信息后,再次发出请求,重新建立连接。
3.当客户端处理接收的数据、重新建立连接时,服务器端可能有新的数据到达:这些信息会被服务器端保存直到客户端重新建立来凝结,客户端会一次把当前服务器端所有信息取回。
3.回传:
PiggyBack(回传)方法是DWR提供的一种"被动式"方法。服务器端将最新的数据排列成队列,然后等待客户端下一次请求,接收到请求后将等待更新的数据发给客户端。DWR会使用某人的设置是PiggyBack,所有在默认情况下,启动反向Ajax时,不会导致服务器超载。
反向Ajax的配置与实现:
要让DWR程序支持反向Ajax,只需要在web.xml中DWRServlet里面添加一个初始化参数,添加内容
<init-param>
<param-name>activeReverseAjaxEnabled</param-name>
<param-value>true</param-value>
</init-param>
如果应用的是轮询技术,则需要添加中下参数:
<init-param>
<param-name>org.directwebremoting.extend.ServerLoadMonitor</param-name>
<param-value>org.directwebremoting.impl.PollingServerLoadMonitor
</param-value>
</init-param>
除了上述配置,为启动反向Ajax,在页面中还需要一些JavaScript代码,
dwr.engine.setActiveReverseAjax(true);
这样就可以使用反向Ajax技术了。