`

DWR推送技术

 
阅读更多
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文件中增加以下配置信息

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> 

<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>Xml代码 
<listener> 
        <listener-class>org.directwebremoting.servlet.EfficientShutdownServletContextAttributeListener</listener-class> 
</listener> 

<listener>
        <listener-class>org.directwebremoting.servlet.EfficientShutdownServletContextAttributeListener</listener-class>
</listener>Xml代码 
<listener> 
        <listener-class>org.directwebremoting.servlet.EfficientShutdownServletContextListener</listener-class> 
</listener> 

<listener>
        <listener-class>org.directwebremoting.servlet.EfficientShutdownServletContextListener</listener-class>
</listener>

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

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> 

<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的源码

Java代码 
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;  
    }  


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类源码

Java代码 
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");  
    }  


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页面源码

Html代码 
<%@ 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> 
分享到:
评论
3 楼 Enock2 2014-12-02  
123
2 楼 Enock2 2014-12-02  
 
1 楼 Enock2 2014-12-02  
[u][/u]

相关推荐

    DWR推送技术大全 dwr推送聊天实例

    DWR推送技术的实现主要涉及以下几个关键组件: 1. **DWR Engine**:这是DWR的核心部分,负责处理JavaScript与服务器端Java对象之间的交互。它通过AJAX(Asynchronous JavaScript and XML)技术在客户端和服务器之间...

    dwr推送技术

    在实际项目中,根据`dwrpush`这个文件名,我们可以推测这是一个关于DWR推送技术的示例或配置文件,可能包含了如何设置和使用DWR推送功能的代码示例。通过对这个文件的深入学习和实践,可以更好地理解和掌握DWR3的推...

    基于dwr推送技术的聊天室

    **基于DWR推送技术的聊天室** DWR(Direct Web Remoting)是一种JavaScript到Java的反向Ajax库,它允许Web应用在浏览器和服务器之间进行实时通信,从而实现动态、交互性强的Web应用。DWR的核心功能在于提供了一种...

    Dwr推送技术实现BS即时通讯

    通过以上分析,我们可以看出"Dwr推送技术实现BS即时通讯"这个项目涉及到了前端与后端的交互、即时通讯机制、数据存储和安全等多个方面的技术,是一个综合性的Web应用开发实践。通过学习和理解这个项目,开发者可以...

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

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

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

    DWR的核心特性是它支持AJAX(Asynchronous JavaScript and XML)以及服务器推送技术,极大地提高了Web应用的用户体验。 **服务器推送技术**: 传统的HTTP协议是基于请求-响应模型的,即客户端发起请求,服务器响应...

    dwr推送demo,用户互推、服务器推送,

    DWR(Direct Web Remoting)是一种Java技术,用于在浏览器和服务器之间进行实时的、双向的通信,使得...初学者可以通过分析和运行这些代码,深入理解DWR的工作原理和使用方式,从而提升对DWR推送技术的理解和应用能力。

    接收Socket消息通过DWR推送到界面显示

    3. **DWR推送技术**:DWR的推送功能是其一大特色,它使得服务器可以主动将数据推送给客户端,而不是等待客户端发起请求。这种机制通常被称为Comet技术,它可以实现实时性,比如聊天应用、股票报价或者在线游戏等场景...

    dwr后台推送

    这份PPT可以作为深入理解DWR推送技术的补充资料。 另外,`DWR推技术在开发中需要注意的ScriptSession问题 - zhyiwww - BlogJava.mht`文件可能包含了开发者在实际开发过程中遇到的一个常见问题——ScriptSession。...

    dwr推送及js访问java代码

    在“dwr推送及js访问java代码”的项目中,我们可以看到如何利用DWR进行双向通信。首先,DWR的核心组件包括`DWR Engine`、`Servlet`和`AutoBean`等。`DWR Engine`负责在客户端和服务器之间建立连接,`Servlet`处理...

    使用dwr+spring实现消息推送

    在IT行业中,消息推送是一项重要的技术,它使得服务器能够实时地向客户端发送数据,而无需客户端不断地轮询请求。在本教程中,我们将探讨如何利用Direct Web Remoting (DWR) 和Spring框架来实现这样的功能。 DWR是...

    DWR消息推送简单实例

    在这个实例中,我们可能会看到如何利用DWR的长轮询技术实现简单的消息推送。 3. **Maven工程** 提到"Maven工程"意味着这个示例项目是使用Maven构建的。Maven是Java项目管理工具,它帮助管理项目的依赖关系,构建...

    实现 Dwr 服务器推送

    DWR (Direct Web Remoting) 是一种开源的Java库,用于在Web应用...同时,随着WebSocket等技术的发展,DWR的服务器推送功能可能逐渐被取代,但在一些老项目或对兼容性有较高要求的场景下,DWR仍然是一种有效的解决方案。

    dwr推技术官方实例

    标题中的“dwr推技术官方实例”是指DWR提供的关于其推技术的实际操作示例,这些示例可能涵盖了DWR 2.0.4及以上版本的最新功能。由于高质量的实例资源在网络上可能不易找到,所以这份实例集合显得尤为宝贵。 描述中...

    dwr实现消息精确推送

    ### dwr实现消息精确推送详解 #### 一、前言 Direct Web Remoting(DWR)是一种开源技术,它使得JavaScript可以直接调用服务器端的Java方法成为可能,从而简化了客户端与服务器之间的交互过程。本篇文章将详细介绍...

    dwr demo 反向推送 导向推送

    这个"**dwr demo 反向推送 导向推送**"是一个示例项目,展示了如何利用DWR来实现反向推送技术,也称为服务器推送。这种技术允许服务器主动地将数据推送到客户端,而不需要客户端不断地发起请求。 在传统的HTTP协议...

    dwr 推送例子,CHAT

    这两个文件展示了DWR推送的两种不同实现方式。 1. `java-chat.html`:这个例子中,服务器端负责主动推送消息到客户端。在Java后端,开发者需要创建一个`PushEngine`实例,注册监听器,并在有新消息时触发推送。DWR...

    springMVC+dwr技术实现消息推送实例

    传统的Ajax技术通常依赖于浏览器发起请求,而DWR则允许服务器主动向客户端推送数据,无需等待用户的操作。这种特性使得DWR在实时应用如聊天、股票报价、在线游戏等场景中非常有用。 **消息推送原理** 消息推送的...

Global site tag (gtag.js) - Google Analytics