一、配置web.xml
<!-- DWRServlet -->
<servlet>
<servlet-name>dwr-invoker</servlet-name>
<servlet-class>org.directwebremoting.servlet.DwrServlet</servlet-class>
<init-param>
<!-- 默认为false,调试用,可以访问http://地址:端口/上下文/dwr 来进行测试 -->
<param-name>debug</param-name>
<param-value>true</param-value>
</init-param>
<!--DWR反转调用的开关,默认是false -->
<init-param>
<param-name>activeReverseAjaxEnabled</param-name>
<param-value>true</param-value>
</init-param>
<!--日志级别 -->
<init-param>
<param-name>logLevel</param-name>
<param-value>WARN</param-value>
</init-param>
<!--把使用DWR注释的类都要加在这里 DWR注解使用可参考:http://rabby.iteye.com/blog/774553 -->
<init-param>
<param-name>classes</param-name>
<param-value>
org.relax.service.SectionManager,
org.relax.service..entity.Section
</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>dwr-invoker</servlet-name>
<url-pattern>/dwr/*</url-pattern>
</servlet-mapping>
二、DWR逆向调用模式
dwr的逆向ajax其实主要包括两种模式:主动模式和被动模式。其中主动模式包括Polling和Comet两种,被动模式只有Piggyback这一种。
所谓的Piggyback指的是如果后台有什么内容需要推送到前台(即调用页面的js方法),是要等到那个页面进行下一次ajax请求的时候,将需要推送的内容附加在该次请求之后,传回到页面。
polling指的是由浏览器定时向服务端发送ajax请求,询问后台是否有什么内容需要推送,有的话就会由服务端返回推送内容。这种方式和我们直接在页面通过定时器发送ajax请求,然后查询后台是否有变化内容的实现是类似的。只不过用了dwr之后这部分工作由框架帮我们完成了。
comet模式指的的当服务端建立和浏览器的连接,将页面内容发送到浏览器之后,对应的连接并不关闭,只是暂时挂起。如果后面有什么新的内容需要推送到客户端的时候直接通过前面挂起的连接再次传送数据。
通过上面的解释我们可以看到,这三种模式都有各自的优缺点。从客户端请求次数的角度来说,当然是piggyback的模式最好。这个里面完全没有额外的网络请求,只有等到下次请求页面主动发起了,中间的变化内容才传递回页面。但是这也导致了这推送内容的延时,因为你完全没办法知道页面的下一次请求将在什么时候发起,也许页面永远都没有下一次请求。polling模式的网络请求最为频繁了,因为这时候页面不管后台有没有更新的内容,都需要发送请求询问。虽然这种模式可以通过增加请求间隔的时间来减少单位时间内的请求次数,但是这样同样会导致页面响应后台内容变化的间隔时间增长,这中间就产生了矛盾,具体的请求间隔时间还是要根据具体项目的需求来配置。比如服务器能承受的请求间隔和页面内容所需要的刷新频率。comet方式的响应速度应该是最快的,后台一旦有内容需要推送可以通过前面没有关闭的连接马上推送到前台。但是服务器所能提供的连接数目是一定的,在大量的挂起的连接没有关闭的情况下,可能造成新的连接请求不能接入,从而影响到服务质量。
三、编写java代码
@RemoteMethod
public synchronized void start() {
WebContext wctx = WebContextFactory.get();
String currentPage = wctx.getCurrentPage();
running = true;
for (int i = 0; i < 1000; i++) {
if (!running) {
break;
}
ScriptBuffer script = new ScriptBuffer();
script.appendScript("receiveMessages(").appendData(i)
.appendScript(");");// 调用页面的javascript方法把值添到页面上。
// Loop over all the users on the current page
Collection pages = wctx.getScriptSessionsByPage(currentPage);// 循环出所有的会话页面并执行
for (Iterator it = pages.iterator(); it.hasNext();) {
System.err.println(i);
ScriptSession otherSession = (ScriptSession) it.next();
otherSession.addScript(script);
}
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
@RemoteMethod
public void stop() {
running = false;
}
四、编写jsp页面
<?xml version="1.0" encoding="UTF-8" ?>
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<script type='text/javascript'
src='/dymc-web/dwr/interface/sectionManager.js'></script>
<script type='text/javascript' src='/dymc-web/dwr/engine.js'></script>
<script type="text/javascript">
function receiveMessages(msg) {
//alert(msg);
document.getElementById("content").innerHTML = msg;
</script>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>DWR反向调用</title>
</head>
<body onload="dwr.engine.setActiveReverseAjax(true)">
<button onclick="sectionManager.start()">start</button>
<button onclick="sectionManager.stop()">stop</button>
<div id="content"></div>
</body>
</html>
五、测试
运行起来后点start按钮,看看页面上是不是自己开始变了。新打开个IE,用另外的机器访问此面,发现都有数字在变换,这就是DWR Reverse Ajax的厉害所在了。再点一下stop,呀,所有打开IE里数字都不变了吧。
注意:代码用的是主动的方式,所以注意页面onload中的<body onload="dwr.engine.setActiveReverseAjax(true)">,没有这句可就不好用了.
分享到:
相关推荐
例如,要启用Active模式,需要在DWR的Servlet配置中设置`activeReverseAjaxEnabled`为`true`,并在页面加载时调用`dwr.engine.setActiveReverseAjax(true)`。Active模式下有三种子模式:Full Streaming Mode、Early ...
Direct Web Remoting (DWR) 是一个开源Java库,它允许在浏览器和服务器之间进行安全、高效的异步通信,即所谓的“反向AJAX”或“Comet”技术。DWR使得JavaScript能够调用服务器端的Java方法,就像它们是本地函数一样...
总的来说,DWR反向推送技术为开发富互联网应用(RIA)提供了一种有效的方法,让Web应用更加互动和实时。通过深入理解和实践DwrTest项目,你可以更好地掌握如何在实际项目中利用DWR实现各种功能。
DWR (Direct Web Remoting) 是一个开源Java库,它允许在浏览器和服务器之间进行实时的、异步的通信,即所谓的反向Ajax技术。在"DWR 3.0反向实例"中,我们将深入探讨这个版本的新特性、配置过程以及如何通过一个简单...
它允许JavaScript在客户端与服务器端的Java对象之间进行直接调用,无需刷新页面,从而实现了所谓的“反向Ajax”或者“富互联网应用”(RIA)的功能。本课件主要涵盖了DWR的基本用法和常见操作,包括数据类型的处理、...
总结来说,"dwr demo 反向推送 导向推送"是一个演示如何使用DWR实现实时服务器推送的项目,它包括了必要的配置和JavaScript调用,对于理解DWR的工作原理以及在实际项目中应用反向推送技术非常有帮助。通过学习这个...
2. **Reverse AJAX**:DWR利用长轮询或IFrame等技术实现反向AJAX,即服务器主动向客户端推送数据,而不仅仅是响应客户端的请求。 3. **JavaScript Interface**:DWR自动生成JavaScript接口,使得前端可以直接调用...
同时,DWR还支持服务器端反向调用,即服务器可以主动触发前端的JavaScript函数,这对于实时更新、推送通知等场景非常有用。 在提供的压缩包文件列表中: 1. **Spring与DWR集成.doc** - 这可能是一个文档,详细介绍...
1. **反向Ajax**:DWR实现了一种反向Ajax(Reverse Ajax)技术,使得服务器能够主动向客户端推送数据,而不仅仅是响应客户端的请求。 2. **JavaScript与Java的桥接**:DWR通过动态生成JavaScript库来映射Java对象和...
- **Reverse Ajax**:DWR使用反向Ajax实现服务器向客户端的推送,使得服务器能够主动更新客户端的状态。 - **Cafe豆**:Cafe豆是一种特殊的Java类,用于定义可从JavaScript访问的Java对象和方法。 3. **DWR的使用...
2. **反向Ajax(Reverse Ajax)**:DWR实现了反向Ajax,即服务器可以主动推送数据到客户端,这是通过HTTP长轮询、WebSocket等技术实现的。 3. **配置DWR**:在项目中集成DWR需要在web.xml文件中配置DWR的Servlet,...
DWR提供了自动转换Java对象到JavaScript对象以及反向转换的功能,使得数据交换变得简单。 **DWR分页实现步骤:** 1. **配置DWR**:在Web应用的`WEB-INF`目录下创建`dwr.xml`配置文件,定义允许JavaScript调用的...
1. **反向Ajax(Reverse Ajax)**:DWR的核心是反向Ajax技术,它打破了传统的请求-响应模式,允许服务器主动推送数据到客户端,而不必等待用户的触发。 2. **Java远程调用(Remote Method Invocation, RMI)**:DWR...
- **Reverse Ajax**:DWR的核心特性是反向Ajax,即服务器可以主动向客户端发送数据,而不仅仅局限于客户端发起请求。 - **CORS(跨源资源共享)**:DWR通过实现CORS策略,允许不同源的JavaScript与服务器进行通信...
6. **DWR的安全性**:DWR提供了安全特性,如JavaScript反向工程防护、CSRF(跨站请求伪造)防护等,以防止恶意攻击。 7. **DWR的调试和日志**:DWR内置了调试模式,可以在浏览器控制台查看调用的详细信息。同时,...
6. **DWR的高级特性**:如批量调用、反向AJAX(使服务器能主动更新客户端)、自定义转换器和适配器、以及DWR的集成框架,如Spring和Struts。 而“dwr.war”文件是DWR的可部署包,通常用于将DWR服务部署到Servlet...
DWR的核心在于其反向AJAX技术,它通过建立一个HTTP长连接,使得服务器端可以主动推送数据到客户端,而不仅仅是响应客户端的请求。 **1. DWR框架的核心组件** - **Engine**: 引擎是DWR的核心,负责处理所有与远程...
2. **反向AJAX**:DWR支持反向AJAX,即服务器可以主动向客户端推送数据,创建实时更新的Web应用。 3. **自动类型转换**:DWR自动处理Java对象到JavaScript对象以及反之的类型转换,简化了数据交换的复杂性。 4. **...
- **Reverse Ajax(反向Ajax)**: DWR实现了反向Ajax,即服务器可以主动推送数据到客户端,而不仅仅是响应客户端的请求。 - **Caching(缓存)**: DWR支持缓存服务器端的响应,提高性能,减少网络流量。 ### 2. ...