`
tudou721
  • 浏览: 61407 次
  • 性别: Icon_minigender_2
  • 来自: 河南
社区版块
存档分类
最新评论

dwr学习入门

阅读更多

DWR可以让你在浏览器中的Javascript代码调用Web服务器上的Java,就像是Java代码就在浏览器中一样。

DWR主要包括两部分:

在服务器上运行的Servlet来处理请求并把结果返回浏览器。
运行在浏览器上的Javascript,可以发送请求,并动态改变页面。
DWR会根据你的Java类动态的生成Javascript代码。这些代码的魔力是让你感觉整个Ajax调用都是在浏览器上

发生的,但事实上是服务器执行了这些代码,DWR负责数据的传递和转换。
这一过程不需要额外的浏览器插件。

下载地址 http://directwebremoting.org/dwr/download

配置文件dwr.xml 默认情况下,应该把它放到WEB-INF下的lib目录(同web.xml的目录)下

结构如下:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE dwr PUBLIC
    "-//GetAhead Limited//DTD Direct Web Remoting 1.0//EN"
    "http://www.getahead.ltd.uk/dwr/dwr10.dtd">
<dwr>
  <!-- init is only needed if you are extending DWR -->
  <init>
    <creator id="..." class="..."/>
    <converter id="..." class="..."/>
  </init>

  <!-- without allow, DWR isn't allowed to do anything -->
  <allow>
    <create creator="..." javascript="..."/>
    <convert converter="..." match="..."/>
  </allow>

  <!-- you may need to tell DWR about method signatures -->
  <signatures>
    ...
  </signatures>
</dwr>

 我们必须理解一些术语 - 参数会被converted,远程bean会被created。所以如果你有一个叫A的bean,它

有一个方法叫A.test(B) 那么你需要一个A的creator和一个B的converter。

<allow>段落里面定义的是DWR可以创建和转换的类。

<create>定义我们要调用的每个类。creator有几种,比较通用的是new关键字和Spring。

<convert>一般来说JavaBean的参数需要一个<convert ...>定义,我们必须保证所有的参数都可以被转换。JDK中的多数类型已经有转换器了,但是你需要给DWR转换你的代码的权利。

默认情况下,如下类型不需要定义就可以转换:

  • 所有的原生类型 boolean,int,double, 等等
  • 原生类型的对象类型 Boolean,Integer,等等
  • java.lang.String
  • java.util.Date 和SQL中的Date
  • 以上类型组成的数组
  • 以上类型的集合类型 (Lists, Sets, Maps, Iterators, 等)
  • 从DOM, XOM, JDOM 和 DOM4J中的DOM对象 (类似 Element 和 Document)

<init>可选的init部分用来声明创造bean的类和转换bean的类。多数情况下不需要用到他们。如果需要定义一个新的Creator 和 Converter , 那么就需要在这里定义他们。但是建议先检查一下DWR是不是已经支持了。

在init部分里有了定义只是告诉DWR这些扩展类的存在,给出了如何使用的信息。这时他们还没有被使用。这中方式很像Java中的import语句。多数类需要在使用前先import一下,但是只有import语句并不表明这个类已经被使用了。每一个creator和converter都用id属性,以便后面使用。 

<signatures>DWR使用反射来找出在转换时应该用哪种类型。有时类型信息并不明确,这时就可以在这里写下方法的签名来明确类型。

其实,一个项目中可以有多个dwr.xml文件,每个文件中的定义会被加在一起。

DWR提供了两个Javascript库

  • engine.js: 处理所有与服务器的通信
  • util.js: 帮你使用从服务器取来的数据改变页面(还有一些灵巧的小功能)

DWR不是一个通用的Javascript库,所以我们尽可能使那些非远程调用相关的功能清晰。尽管如此,util.js有一些小功能会使工作更加容易。

将dwr.jar放到应该把它放到WEB-INF下的lib目录下:

配置web.xml:

   <servlet>
     <servlet-name>dwr-invoker</servlet-name>
     <servlet-class>uk.ltd.getahead.dwr.DWRServlet</servlet-class>
  </servlet>
  <servlet-mapping>
     <servlet-name>dwr-invoker</servlet-name>
   <url-pattern>/dwr/*</url-pattern><!--dwr也可以写成别的,只是导入js时要注意路径-->
  </servlet-mapping>

 在页面上使用要用到dwr的javascript库:

<script type="text/javascript" src="dwr/engine.js"></script>
<script type="text/javascript" src="dwr/util.js"></script>

 相关要用的要自己导入,但要存在于interface包下,如:

 

<script type="text/javascript" src="dwr/interface/math.js"></script>

 上面的js文件来源于dwr.xml的配置:

<allow>
   <create javascript="math" creator="new">
       	<param name="class" value="java.lang.Math"></param>
   </create>
</allow>

 使用math.js:

//输出随机数
  function mm(){
  	math.random(getm);  <--使用Math的方法random-->
  }
  function getm(data){
  	alert(data);
  }

 

<button onclick="mm();">Math</button>

 

点击Math按钮即可得到一个随机数字。这就是dwr的简单使用。

想学dwr,http://wiki.javascud.org/display/dwrcn/Home是个好地方。

分享到:
评论

相关推荐

    dwr学习入门资料

    根据提供的文件信息,我们可以将DWR(Direct Web Remoting)的学习入门资料中的关键知识点进行详细的阐述与解析。本文旨在帮助初学者快速理解DWR的基本概念、配置方式以及如何实现前端JavaScript与后端Java服务之间...

    dwr入门 dwr学习资料

    本套DWR学习资料旨在帮助初学者快速掌握DWR的基本概念和使用技巧。通过实例和详细的说明,你可以系统地了解如何在实际项目中应用DWR。 1. **DWR的基本概念** - **反向AJAX**:DWR的核心技术之一,允许服务器主动推...

    DWR 教程 中文API DWR.xml配置文件说明 DWR学习笔记

    首先,"DWR学习笔记"提供了对DWR基础概念、核心功能以及实际应用的概述。这些笔记可能包含了DWR的基本架构,如它如何通过AJAX技术实现实时的Web交互,以及如何创建和调用服务器端的Java方法。 "DWR中文API"是DWR库...

    AJAX技术之DWR框架入门

    **AJAX技术之DWR框架入门** AJAX(Asynchronous JavaScript and XML)是一种在无需刷新整个页面的情况下,能够更新部分网页的技术。它通过在后台与服务器进行少量数据交换,使得网页实现异步更新。这种技术可以提升...

    dwr框架入门学习文档

    DWR 框架入门学习文档 DWR(Direct Web Remoting)是一个开放源码的使用 Apache 许可协议的解决方案,它包含服务器端 Java 库、一个 DWR Servlet 以及 JavaScript 库。DWR 框架是最成熟的 Ajax-RPC 工具包之一,...

    dwr简单入门例子

    最近发现了一个java框架,这个框架已经是很老的的了,现在才学习用了,真是迟啊。不过现学现用,感觉很不错。这个框架叫dwr,它可以在jsp页面编写js直接调用java的类的方法。原理其实就是它把你的java类发布成了接口...

    DWR框架配置学习教程

    ### DWR框架配置学习教程 #### 一、DWR框架简介与配置 DWR(Direct Web Remoting)是一个用于简化Ajax应用开发的框架,它可以让客户端JavaScript代码直接调用服务器端Java方法,从而大大简化了前端与后端的交互...

    DWR框架学习资料...

    - "DWR学习.ppt":可能深入探讨了DWR的高级特性,如批处理、安全控制和性能优化,适合对DWR有一定了解的学习者提升技能。 6. **学习DWR的好处** - **提升效率**:DWR简化了AJAX开发,减少了前端与后端之间的沟通...

    DWR学习案例详解(数据库)

    在这个DWR学习案例中,你可能会看到如何设置DWR环境,创建Java和JavaScript接口,以及如何进行数据库操作的示例。案例可能包括创建用户界面元素,如表格或表单,用于显示和编辑数据;编写服务器端的Java方法,处理...

    dwr 入门学习资料

    以下是对DWR入门学习资料的详细解释: 1. **DWR的基本概念**: - **Web Remoting**:远程过程调用的概念,使得客户端可以调用服务器端的方法,而无需刷新整个页面。 - **AJAX**:异步JavaScript和XML,通过局部...

    dwr学习之基础篇

    《DWR学习之基础篇——深入理解Direct Web Remoting》 Direct Web Remoting(DWR)是一种开源JavaScript库,它允许在Web浏览器和Java服务器之间进行实时、双向通信,极大地简化了AJAX(Asynchronous JavaScript and...

    学习dwr的一个例子

    此外,理解和掌握AJAX和JavaScript基础知识对于学习DWR非常重要。 10. **实践与调试**:在实际操作中,学习DWR的最佳方法是动手实践。通过调试和修改示例代码,可以更好地理解DWR的工作原理和使用技巧。 总的来说...

    dwr基础_dwr兼容三大框架+视频

    在这个“dwr基础_dwr兼容三大框架+视频”资源中,重点是介绍如何在MyEclipse环境中使用DWR与Spring、Struts2和Hibernate这三大主流Java框架集成。这三大框架分别是: 1. **Spring**:是一个全面的Java应用框架,...

    学习dwr的入门例子

    在这个“学习dwr的入门例子”中,我们将探讨如何使用DWR构建一个简单的Web应用。 首先,了解DWR的基本概念至关重要。DWR的核心功能是创建了一个在客户端和服务器端之间的桥梁,使得JavaScript可以像调用本地函数...

    DWR 1.0 学习示例

    DWR 1.0 版本是早期的一个版本,尽管现在可能已经被更新的版本替代,但它仍为理解Web应用的异步通信提供了很好的学习基础。 在这个学习示例中,我们关注的是如何使用DWR 1.0和JDK 1.4.2来判断用户是否已经注册。JDK...

    dwr学习实例+dwr完整包(简单登陆,完整版,下载可直接跑)

    这个实例为学习DWR提供了一个基础平台,你可以在此基础上深入理解DWR的工作原理,以及如何将它应用于实际项目中,比如扩展登录功能,添加注册模块,或者与其他业务逻辑集成。同时,这也是一个实践数据库操作、Java...

    ajax的DWR框架入门例子

    在这个"ajax的DWR框架入门例子"中,我们将深入理解DWR如何工作以及如何在实际项目中应用。这个例子包含了源代码和调试成功的案例,这意味着我们可以直接运行和学习,而无需从零开始搭建环境。 首先,DWR的基本概念...

    dwr基础学习书籍新手必备

    ### DWR基础学习知识点详解 #### 一、DWR概览与入门 DWR(Direct Web Remoting)是一种简化客户端JavaScript调用服务器端Java方法的技术,它使得远程过程调用(RPC)变得像本地调用一样简单。DWR通过AJAX技术在...

    dwr3_helloword入门

    在本教程中,我们将学习如何使用DWR 3.0进行快速入门,通过一个简单的“Hello, World”实例来理解其工作流程。 首先,我们需要创建一个Web工程,并导入DWR 3.0的相关库。这通常包括DWR的核心JAR包和可能需要的日志...

    Ajax学习——DWR的参考书和实用案例学习总结

    - **DWRchinese.pdf**:这本书可能是中文版的DWR教程,涵盖了DWR的基本概念、安装配置、API使用以及实例解析,适合初学者入门。 - **dwr.war**:这是一个DWR的部署文件,通常用于在Web服务器上快速部署DWR服务。...

Global site tag (gtag.js) - Google Analytics