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 onload="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。
DWR 推技术
最新推荐文章于 2024-11-06 08:40:56 发布