`
xinklabi
  • 浏览: 1590804 次
  • 性别: Icon_minigender_1
  • 来自: 吉林
文章分类
社区版块
存档分类
最新评论

dwr实现Reverse Ajax推送技术的三种方式

 
阅读更多

DWR2.x的推技术也叫DWR Reverse Ajax(逆向Ajax)主要是在BS架构中,从服务器端向多个浏览器主动推数据的一种技术。

 

在DWR所开的线程中使用Reverse Ajax时,通过WebContextFactory.get()获取WebContext对象,进而获取脚本Session。


在DWR之外使用Reverse Ajax时,就要用到ServerContext,在Spring环境中要得到ServerContext,就需要用到Spring的ServletContextAware接口。

 

一、Reverse Ajax的实现有3种方式:

      DWR的逆向Ajax主要包括两种模式:主动模式和被动模式。其中主动模式包括polling和comet两种,被动模式只有piggyback这一种。

 

     1、piggyback方式

           这是默认的方式。

           如果后台有什么内容需要推送到前台,是要等到那个页面进行下一次ajax请求的时候,将需要推送的内容附加在该次请求之后,传回到页面。
           只有等到下次请求页面主动发起了,中间的变化内容才传递回页面。

 

      2、comet方式

           当服务端建立和浏览器的连接,将页面内容发送到浏览器之后,对应的连接并不关闭,只是暂时挂起。如果后面有什么新的内容需要推送到客户端的时候直接通过前面挂起的连接再次传送数据。

           服务器所能提供的连接数目是一定的,在大量的挂起的连接没有关闭的情况下,可能造成新的连接请求不能接入,从而影响到服务质量。

 

      3、polling方式

           由浏览器定时向服务端发送ajax请求,询问后台是否有什么内容需要推送,有的话就会由服务端返回推送内容。这种方式和我们直接在页面通过定时器发送ajax请求,然后查询后台是否有变化内容的实现是类似的。只不过用了dwr之后这部分工作由框架帮我们完成了。

 

 

二、使用DWR的推技术的步骤

     1、在web.xml文件中增加以下配置信息

<servlet>
	<servlet-name>dwr-invoker</servlet-name>
	<servlet-class>uk.ltd.getahead.dwr.DWRServlet</servlet-class>
	<init-param>
		<param-name>debug</param-name>
		<param-value>true</param-value>
	</init-param>
	
	<!-- DWR默认采用piggyback方式 -->
	
	<!-- 使用polling和comet的方式 -->
	<init-param>
		<param-name>pollAndCometEnabled</param-name>
		<param-value>true</param-value>
	</init-param>
	
	<!-- comet方式 -->
	<!-- 
	<init-param>
		<param-name>activeReverseAjaxEnabled</param-name>
		<param-value>true</param-value>
	</init-param>
	 -->
	 
	<!-- polling方式:在comet方式的基础之上,再配置以下参数 -->
	<!-- 
	<init-param>
		<param-name>org.directwebremoting.extend.ServerLoadMonitor</param-name>
		<param-value>org.directwebremoting.impl.PollingServerLoadMonitor</param-value>
	</init-param>
	 -->
	  
	<!-- 毫秒数。页面默认的请求间隔时间是5秒 -->
	<!-- 
	<init-param>
		<param-name>disconnectedTime</param-name>
		<param-value>60000</param-value> 
	</init-param>
	 -->
	 
	<load-on-startup>1</load-on-startup>      
</servlet>

<servlet-mapping>
	<servlet-name>dwr-invoker</servlet-name>
	<url-pattern>/dwr/*</url-pattern>
</servlet-mapping>

 

    2、在dwr.xml中增加以下配置信息

<create creator="new" javascript="DWRHelper">
	<param name="class" value="com.cjm.web.dwr.DWRHelper"/>
	<include method="addMessage"/>
	<include method="test"/>
</create>

<convert converter="bean" match="com.cjm.web.dwr.Message">
	<param name="include" value="id,text"/>
</convert>

 

    3、pojo类Message的源码

public class Message {
	private long id = System.currentTimeMillis();
	private String text;
	
	public Message(){
		
	}
	
	public Message(String newText){
		text = newText;
	}
	
	public long getId() {
		return id;
	}
	public void setId(long id) {
		this.id = id;
	}
	public String getText() {
		return text;
	}
	public void setText(String text) {
		this.text = text;
	}
}

 

     4、DWRHelper类源码

public class DWRHelper {
	private static LinkedList<Message> messages = new LinkedList<Message>();
	private static ReentrantLock lock = new ReentrantLock(); //JDK5锁
	
	public void addMessage(String text){
		try{
			lock.lock();
			
			if(text!=null && text.trim().length()>0){
				messages.addFirst(new Message(text));
				if(messages.size()>10){
					messages.removeLast();
				}
			}
		}catch(Exception ex){
			ex.printStackTrace();
		}finally{
			lock.unlock();
		}
		
		//获得DWR上下文
		WebContext webContext = WebContextFactory.get();
		
		//获取当前页面URL,比如/ext3/test_tag.jsp
		String currentPage = webContext.getCurrentPage();
		
		//当前脚本sessin
		ScriptSession scriptSession = webContext.getScriptSession();
		
		//设置页面控件的值
		Util util = new Util(scriptSession);
		util.setValue("text", ""); //这里是清空页面输入框的值
		
		//设置脚本sessin的属性值
		scriptSession.setAttribute("uid", "cjm");
		
		//获取脚本session的属性值
		for(Iterator it=scriptSession.getAttributeNames();it.hasNext();){
			String attrName = (String)it.next();
			System.out.println(attrName + "=" + scriptSession.getAttribute(attrName));
		}
		
		//获取所有浏览当前页面的脚本session
		Collection<ScriptSession> sessions = webContext.getScriptSessionsByPage(currentPage);
		
		Util utilAll = new Util(sessions);
		
		//执行客户端脚本
		ScriptBuffer script = new ScriptBuffer();
		script.appendScript("clientFunction(")
		  .appendData(scriptSession.getAttribute("uid"))
		  .appendScript(");");
		
		for(ScriptSession session: sessions){
			session.addScript(script);
		}
		
		//更新这些脚本session的一些元素
		utilAll.removeAllOptions("messages");
		utilAll.addOptions("messages", messages, "id", "text");
	}
}

 

    5、JSP页面源码

<%@ page language="java" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
	<script type='text/javascript' src='/ext3/dwr/engine.js'></script>
	<script type='text/javascript' src='/ext3/dwr/util.js'></script>
	<script type='text/javascript' src='/ext3/dwr/interface/DWRHelper.js'></script>
  </head>
  
  <!-- 通过 dwr.engine.setActiveReverseAjax(true); 启动该页面的Reverse Ajax功能  -->
  <body onload="dwr.engine.setActiveReverseAjax(true);sendMessage();">
  	<p>输入信息: <input id="text" onkeypress="dwr.util.onReturn(event, sendMessage)" /> 
	<input type="button" value="Send" onclick="sendMessage()" /></p>

	<script type="text/javascript">
    	function sendMessage() {
      		DWRHelper.addMessage(dwr.util.getValue("text"));
    	}
	</script>
	
	<hr/>
	<select id="messages"></select>
  	
  </body>
</html>
分享到:
评论
1 楼 小小西芹菜 2016-05-26  
我喜欢代码简洁易读,服务稳定的推送服务,前段时间研究了一下goeasy,java后台推送只需要两行代码, js前端推送也只需要3,4行,而且文档齐全,还提供了后台查询信息收发情况,所以我觉得GoEasy推送服务是个不错的选择。
快速入门:goeasy.io/www/started.jsp
GoEasy web实时推送官网:https://goeasy.io
1. 引入goeasy.js
2. 客户端订阅,
   Var goeasy = new GoEasy({appkey:’your appkey’});
goeasy.subscribe(channel:”your channel”, onMessage:function(message){alert(‘received message’+ message.content)})
3. 三种推送方式
   Javascript: goeasy.publish({channel:’your channel’, message:’your publish msg’});
   Java SDK: GoEasy goeasy = new GoEasy(“appkey”); goeasy.publish(“your channel”,”your msg”);
   RestAPI: https://goeasy.io/goeasy/publish
三步轻松实现web推送及接收。

相关推荐

    即时通讯DWR Reverse Ajax

    DWR(Direct Web Remoting)是实现这种功能的一种技术,尤其以其独特的Reverse Ajax特性在服务器推送(Server-Sent Events, SSE,也常被称为Comet技术)领域中备受关注。下面我们将深入探讨DWR Reverse Ajax的工作...

    dwr3ReverseAjax示例

    在描述中提到的“反向Ajax”(Reverse Ajax)是一种技术,它使得服务器可以主动向客户端推送数据,而不仅仅局限于客户端发起请求后服务器响应的传统模式。DWR支持这种模式,通过建立持久连接或者利用浏览器的长轮询...

    dwr 2.0(reverse ajax)实现推的web IM例子

    在DWR 2.0版本中,引入了Reverse Ajax的概念,这是一种服务器主动向客户端推送数据的技术,这对于构建实时的Web应用程序,比如Web IM(即时通讯)应用,非常关键。 在这个例子中,我们将探讨如何利用DWR 2.0实现一...

    dwr推技术实现服务器推送数据

    总结来说,DWR推技术是实现服务器主动向客户端推送数据的一种高效方式,尤其适用于需要实时数据更新的应用,如股票实时显示。通过反转Ajax,DWR简化了开发流程,提高了用户体验,是现代Web开发中的一个重要工具。

    Dwr 官方Reverse Ajax Demo

    它通过JavaScript API在浏览器端与Java方法交互,从而实现了Reverse Ajax(也称为Comet技术),即服务器向客户端推送数据的能力。** **一、DWR的核心功能** 1. **双向通信**:DWR提供了从浏览器到服务器以及从...

    DWR3实现服务器端向客户端精确推送消息

    要实现服务器端向客户端的精确推送,DWR3提供了“Reverse Ajax”或者称为“Comet”技术。Comet是一种使服务器能够长时间保持HTTP连接开放的技术,以便在需要时向客户端发送更新。这种长轮询或流式传输的方式,使得...

    DWR服务器推送技术(实时)

    DWR使用一种称为Reverse Ajax或Comet的技术来实现服务器推送。它创建了一个持久化的HTTP连接,使得服务器可以在准备好新数据时立即发送,而不需要等待客户端的请求。DWR提供了一种简单的方式来注册JavaScript函数,...

    dwr服务器推送,dwr.jar,推送,服务器ajax,dwr服务推送例子

    服务器推送技术在DWR中的实现主要通过以下几种方式: - **Polling**:定时轮询是最常见的实现方式,客户端以一定的频率向服务器发送请求,询问是否有新的数据。 - **Reverse Ajax**:DWR支持真正的服务器推送,即当...

    基于DWR框架的Web推送技术实现

    在Web推送技术中,DWR的`ReverseAjax`机制起着关键作用。当服务器有新的消息需要推送给客户端时,DWR会创建一个持久的HTTP连接,保持客户端与服务器的连接状态。一旦服务器端的数据发生变化,DWR会通过这个连接立即...

    dwr 实现推技术 实例

    1. **反向Ajax(Reverse Ajax)**:DWR的核心功能之一是实现反向Ajax,即服务器可以主动向客户端推送数据,而不仅仅是响应客户端的请求。这使得Web应用能够实现类似桌面应用的即时更新效果。 2. **安全机制**:DWR...

    dwr消息推送完整示例

    DWR利用Reverse Ajax技术实现服务器向客户端的推送。传统Ajax是客户端发起请求,服务器响应;而Reverse Ajax则是服务器主动向客户端发送数据,无需客户端持续轮询。 2. **心跳机制** 为了保持连接,DWR使用心跳...

    dwr spring服务器主动推送示例代码

    本示例将深入探讨如何使用DWR与Spring框架集成,实现服务器主动推送功能。 首先,我们需要理解DWR的核心概念: 1. **DWR Engine**: 是DWR的核心组件,它处理客户端和服务器之间的通信,包括JavaScript到Java的调用...

    DWR 简单额服务器推送技术DEMO

    在DWR中,服务器推送是通过一种叫做"Reverse Ajax"或者"Comet"的技术实现的。这种方式可以让服务器在接收到客户端的一个请求后,保持连接开放状态,并在合适的时候通过同一个连接向客户端发送数据,而不是等待客户端...

    DWR的推技术

    在DWR 2.x版本中,引入了推技术,即所谓的“Reverse Ajax”,这是一种在BS(Browser/Server)架构中,让服务器主动向客户端推送数据的技术,以实现实时或近乎实时的数据更新,而无需页面刷新。 #### 二、Reverse ...

    dwr+从服务端推送消息到网页

    在传统的HTTP协议中,客户端需要发起请求才能获取服务器数据,而DWR的`ReverseAjax`技术,通过长轮询、流或WebSocket等方式实现了服务端向客户端的推送。对于初学者来说,理解并实现服务端推送是掌握DWR的关键。 4...

    dwr3消息推送

    - DWR3支持两种推送模式:Polling(轮询)和Reverse AJAX(逆向AJAX,也称为Comet)。 - Polling是客户端定期向服务器发送请求检查新消息,而Reverse AJAX则是在服务器端保持一个开放的HTTP连接,直到有新消息时才...

    基于dwr的java推送消息慕课小项目

    本项目基于DWR,探讨如何实现Java消息的推送功能,以提升Web应用的即时性。 **DWR框架简介** DWR是一种让Java方法在浏览器中可调用的技术,通过在服务器端创建一个Java接口,该接口的方法可以被JavaScript直接调用...

    dwr实现服务器推技术,兼容低版本IE

    DWR的`Caucho Resin`服务器提供了一种称为Reverse Ajax或Comet的技术,实现了服务器推送。它通过长时间连接保持HTTP请求开放,直到服务器有新数据可推送给客户端。 3. **兼容低版本IE** Internet Explorer在某些...

    dwr java推送例子 免积分

    在DWR中,推送是通过Reverse Ajax或Comet技术实现的。Comet是一种持久连接技术,它允许服务器在准备好新数据时主动向客户端发送,而不是传统的客户端发起请求获取数据。这在实时性要求高的应用中,如聊天、股票报价...

    dwr后台推送

    在DWR 2.0中,后台推送主要通过"Reverse Ajax"(Comet)实现,这是一种使服务器能够主动向客户端发送数据的技术。DWR 2.0的Push功能通过`CallRemoteFunction`和`AddReverseAjax`接口实现,开发者可以创建一个长轮询...

Global site tag (gtag.js) - Google Analytics