下面是从一个实例的构建过程进行分析。
1、DWR 介绍
DWR是一个可以允许你去创建AJAX WEB 站点的JAVA 开源库。它可以让你在浏览器中的Javascript代码调用Web服务器上的Java 代码,就像在Java代码就在浏览器中一样。
DWR包含 2个主要部分:
(1) 一个运行在服务器端的Java Servlet,它处理请求并且向浏览器发回响应。
(2) 运行在浏览器端的JavaScript,它发送请求而且还能动态更新网页。
DWR工作原理是通过动态把Java类生成为Javascript。它的代码就像Ajax魔法一样,你感觉调用就像发生在浏览器端,但是实际上代码调用发生在服务器端,DWR负责数据的传递和转换。这种从Java 到JavaScript的远程调用功能的方式使DWR用起来有种非常像RMI或者SOAP的常规RPC机制,而且DWR的优点在于不需要任何的网页浏览器插件就能运行在网页上。
2、DWR 配置文件说明
web.xml
<servlet>
<servlet-name>dwr</servlet-name>
<!-- 如果是dwr1.x 的话,下面的class为:uk.ltd.getahead.dwr.DWRServlet -->
<servlet-class>org.directwebremoting.servlet.DwrServlet</servlet-class>
<!-- 在开发期间,把这个设成true,有助于调试,可通过 http://localhost/XXXX(应用空间名)/dwr 进行查看 -->
<init-param>
<param-name>debug</param-name>
<param-value>true</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>dwr</servlet-name>
<url-pattern>/dwr/*</url-pattern>
</servlet-mapping>
关于这个配置文件,没什么好说的,等深入了解后再做解析。。
dwr.xml
<dwr>
<!-- 仅当需要扩展DWR时才需要,这里不做例子,等深入分析后才做介绍 -->
<!--
<init>
<creator id="..." class="..." />
<converter id="..." class="..." />
</init>
-->
<allow>
<create javascript="UserDao" creator="new" scope="session">
<param name="class" value="user.UserDao"></param>
<!-- 也可以设置不可访问的方法
<exclude method="xxx"/>
-->
<!-- 设置可访问的方法 -->
<include method="say" />
<include method="getUser" />
<include method="setDates" />
</create>
<!-- 声明的javascript 调用Bean-->
<convert match="user.User" converter="bean">
<param name="include" value="id,name"></param>
</convert>
</allow>
<!-- 使DWR能确定集合中存放的数据类型 -->
<signatures>
<![CDATA[
import java.util.Date;
public void setDates(List<Date> dates);
]]>
</signatures>
</dwr>
配置的参数简单分析:
(详细分析,请参考dwr 文档)
<init>标签
这个初始化部分申明被用来创建远程beans 而且这个类能被用来以某种过程转换。大多数例子你将不需要
用它,如果你想去定义一个新的Creator 或者Converter,就要在此被申明。
<allow>标签
allow部分定义了DWR能够创建和转换的类。
<create> 标签
每一个在类中被调用的方法需要一个<create …>有若干类型的creator,使用“new”关键字或者Spring 框架等。
<convert>标签
我们需要确认所有的参数能被转换。 许多JDK提供的类型使你能够使用,但是你如果要转换你自己的代码,就必须告诉DWR。一般是指JavaBean 的参数需要一个<convert…>标签作为入口。
<signatures>标签
DWR使用反射机制在转换过程中找到它应该使用的类型。有时候类型的信息无法获得,在这种情况下你要在此处用方法签名给予暗示。
signatures段使DWR能确定集合中存放的数据类型。例如下面的定义中我们无法知道list中存放的是什么类型。
3、Html 分析
<html>
<head>
<title>dwr-demo</title>
<!--
javascript 能访问的类都要在此设定,命名以javascript 属性为准,结合dwr.xml
<create javascript="UserDao" creator="new" scope="session">
-->
<script type="text/javascript" src="/dwr-dome/dwr/interface/UserDao.js"></script>
<!--这个属性必须设定 -->
<script type="text/javascript" src="/dwr-dome/dwr/engine.js"></script>
<!--当用到dwr 集成的javascript 工具类时要设定 -->
<script type="text/javascript" src="/dwr-dome/dwr/util.js"></script>
<!-- 外部的javascript 文件 -->
<script type="text/javascript" src="/dwr-dome/user.js"></script>
</head>
<body>
<form id="userform">
<input type="text" id="name" name="name">
<input type="button" onclick="say()" value="say">
<input type="button" onclick="getuser()" value="getuser">
<input type="button" onclick="setdates()" value="setdates">
</form>
<font color="red"><div id="say"></div>
</font>
<font color="red"><div id="getuser"></div>
</font>
<font color="red"><div id="setdates"></div>
</font>
</body>
</html>
分析:
engine.js文件
engine.js对 DWR非常重要,因为它是用来转换来至动态生成的接口的javascript 函数调用的,所以只要用到DWR的地方就需要它。
util.js文件
util.js包含了一些工具函数来帮助你用javascript 数据(例如从服务器返回的数据)来更新你的 web页面。你可以在DWR以外使用它,因为它不依赖于DWR的其他部分。你可以下载整个DWR或者单独下载.
这个工具类能使dwr 更加方便的使用,具体的函数分析,请参考dwr文档。
4、外面的js 文件(user.js)
function say(){
var name=$("name").value;
UserDao.say(name,callback);
}
function callback(data){
$("say").innerHTML=data;
}
function getuser(){
UserDao.getUser(calluser);
}
function calluser(user){
var info="you id is "+user.id+" .you name is "+user.name;
$("getuser").innerHTML=info;
}
function setdates(){
var list=[new Date(),new Date()];
UserDao.setDates(list,calldate);
}
function calldate(datestring){
$("setdates").innerHTML=datestring;
}
这个文件主要应用到了dwr 的util.js 的工具类。还有关于回调函数这两方面比较重要。
关于回调函数,主要是在java 类函数的基础上,加多个参数,
如在java 中的函数:UserDao.say(name); 在javascript的函数(包括回调):UserDao.say(name,callback);
有篇文章分析的很多,请参考:http://blog.sina.com.cn/s/blog_496aa28601000738.html
实际的运行结果图:
其他的文件没什么可分析的,请参考下面给出的源码。
关于在做这个实例的时候遇到的几个问题:
1、dwr2.05 中除了加入dwr.jar 还必须加入commons-logging.jar,不然会报错。。
2、在dwr.xml 配置中 <create javascript="UserDao" creator="new" scope="session">
scope 应设为session,在getuser中才能取得User 的属性值。
下面给出一些参考的网站:
DWR中文文档 :http://wiki.javascud.org/display/dwrcn/Home
DWR官方网站:http://directwebremoting.org/
- 大小: 11.2 KB
分享到:
相关推荐
首先,"DWR学习笔记"提供了对DWR基础概念、核心功能以及实际应用的概述。这些笔记可能包含了DWR的基本架构,如它如何通过AJAX技术实现实时的Web交互,以及如何创建和调用服务器端的Java方法。 "DWR中文API"是DWR库...
在“DWR学习笔记及经验总结”中,我们可以期待找到以下关键知识点: 1. **DWR的基本概念**:了解DWR的核心理念,包括远程方法调用(Remote Method Invocation)、反向Ajax以及它如何通过JSON或XML格式传递数据。 2...
**DWR(Direct Web Remoting)**是一种JavaScript库,它允许Web...通过深入学习和实践"DWR学习笔记和与spring整合练习",开发者可以掌握DWR的精髓,熟练运用其与Spring的整合,打造出高效、安全、易维护的Web应用程序。
### dwr学习笔记pdf文件知识点概述 #### 一、DWR框架简介 - **DWR**(Direct Web Remoting)是由GetAhead公司开发的一款用于实现Ajax应用的框架。该框架的核心价值在于允许客户端JavaScript直接调用服务器端Java类...
### dwr学习笔记和总结 #### 一、DWR简介 DWR (Direct Web Remoting) 是一个简化Ajax开发的框架,它使得JavaScript能够直接调用服务器端的Java方法成为可能,无需编写复杂的Ajax代码。这极大地提高了开发效率,并...
【标题】:“DWR学习笔记-HelloWorld篇” 在IT领域,DWR(Direct Web Remoting)是一个开源的Java框架,它允许JavaScript在浏览器端直接调用服务器端的Java方法,实现了网页与服务器的实时交互,类似于Ajax技术,但...
总结来说,这个"DWR学习笔记"示例涵盖了以下知识点: 1. DWR的基本概念和工作原理,包括Reverse Ajax机制。 2. 如何在服务器端配置DWR,定义可调用的Java服务。 3. 客户端如何使用DWR的JavaScript库与服务器进行通信...
《DWR学习笔记详解》 DWR(Direct Web Remoting)是一种开源JavaScript库,它允许在Web浏览器和Java服务器之间进行实时、双向通信,极大地增强了Web应用的交互性。DWR使得开发者能够像操作本地对象一样操作服务器端...
1. **官方文档**:DWR的官方文档详细介绍了如何配置、使用以及扩展DWR,是学习的好资料。 2. **示例代码**:实践是最好的老师,通过分析和运行提供的jar文件中的示例代码,能更深入理解DWR的工作原理。 3. **社区...
**DWR(Direct Web Remoting)学习笔记** DWR是一种Java技术,用于在浏览器和服务器之间实现双向通信,使得Web应用程序能够实时更新和交互。它允许JavaScript直接调用服务器端的Java方法,就像它们是本地函数一样,...
DWR(Direct Web Remoting)是一种Java库,用于在Web应用程序中实现JavaScript和服务器端Java对象之间的双向通信。它使得动态、实时的Web界面成为可能,而无需刷新整个页面。以下是对DWR配置和工程实例的详细解释: ...