DWR2.0.x的推技术以推发送消息,适用于ChatRoom,股票信息显示等场景,优于现在JS定时轮询服务端的策略,大大节省服务端的资源(数据无变化时不需要应答客户端的定时查询)。
在2.0M3开始终于能够正常运作。(注意,2.0M3需要到http://dwr.dev.java.net下载)
推技术的经典范例是DWR Examples里的ChatRoom,另外SpringSide里的场景也非常实在。
1. 推消息的接收页
1.<script type='text/javascript' src='<c:url value="/dwr/engine.js"/>'></script>
<script type='text/javascript' src='<c:url value="/dwr/interface/orderNotice.js"/>'></script>
<script type='text/javascript' src='<c:url value="/dwr/util.js"/>'></script>
2.<script language="javascript">
function receiveMessages(id) {
$('orderNotice').innerHTML = "收到id为" + id + "的新订单!";
$('orderNotice').show();
}
</script>
3.<body οnlοad="DWREngine.setReverseAjax(true);">
<div id="orderNotice"/>
第一,引入dwr及那个负责执行推操作的Java类(OrderNotice)的js
第二,设定任意的接收推信息的js函数
第三,在body的onload里设定ReverseAjax=true,开始侦听信息
详见springside-bookstore/webapp/admin/top.jsp
2.负责推送消息的Java类
public class OrderNotice {
public void noticeNewOrder(int id) {
WebContext wctx = WebContextFactory.get();
ScriptBuffer script = new ScriptBuffer();
script.appendScript("receiveMessages(")
.appendData(id)
.appendScript(");"); ServerContext sctx = ServerContextFactory.get(wctx.getServletContext());
Collection<ScriptSession> pages = sctx.getScriptSessionsByPage("/springside/admin/top.jsp");
for (ScriptSession session : pages) {
session.addScript(script);
}
}
}可见,用ScriptBuffer构造一段在客户端执行的SQL,然后使用WebContext ,ServerContext 定位需要发送的session进行发送。注意这里HardCode了URL路径来确定Subscriber,也可以像ChatRoom里面那样,用currenpage 发给与orderNotice的调用者发起者在同一页的session。
3.其余工作
设定dwr.xml,按Dwr的老模式,从客户端调用OrderNotice。
本文来自优快云博客,转载请标明出处:http://blog.youkuaiyun.com/cxhzqhzq/archive/2008/07/07/2621081.aspx