`

DWR学习笔记(一)

    博客分类:
  • DWR
阅读更多

一.DWR简介
  
  1.DWR是一个可以允许你去创建AJAX WEB站点的JAVA开源库。
    它可以让你在浏览器中的Javascript代码调用Web服务器上的Java代码,就像Java代码在浏览器中一样。
    
  2.DWR包含2个主要部分:
     I.一个运行在服务器端的Java Servlet,它处理请求并且向浏览器发回响应。
    II.运行在浏览器端的JavaScript,它发送请求而且还能动态更新网页。
   
  3.DWR工作原理是通过动态把Java类生成为Javascript。
    它的代码就像Ajax魔法一样,你感觉调用就像发生在浏览器端,但是实际上代码调用发生在服务器端,DWR负责数据的传递和转换。
    这种从Java到JavaScript的远程调用功能的方式使DWR用起来有种非常像RMI或者SOAP的常规RPC机制,
    而且DWR的优点在于不需要任何的网页浏览器插件就能运行在网页上。
    
  4.Java从根本上讲是同步机制,然而AJAX却是异步的。
    所以你调用远程方法时,当数据已经从网络上返回的时候,你要提供有反调(callback)功能的DWR(JS函数)。
    
 二.DWR的使用步骤:一共有五步:
         *导入dwr.jar
         *配置web.xml
         *配置dwr.xml
         *生成java类
         *生成JSP页面
  
  1.导入DWR到工程
     A.将dwr.jar库文件拷贝到项目的lib目录(dwr.jar会要求一个辅助类库commons-logging.jar来支持日志输出)
     B.将engine.js和util.js两个DWR的js文件拷贝到项目的js目录(下载的zip文件 \java\org\directwebremoting中有这两个文件)

   **注意:经测试engine.js和util.js不需要导入项目js目录中,
     然后界面中使用的是dwr.jar中的engine.js和util.js文件,直接导入就行,见下边jsp文件
     当然如果导入也不会有错,只不过没有使用罢了,但是导入的话可以有种提示自己要在页面导入这两个文件的作用。
   
  2.注册DWR到项目的web.xml配置文件(其实就是添加一个DWR的Servlet)
   
   <servlet>
      <servlet-name>dwr-invoker</servlet-name>
      <servlet-class>org.directwebremoting.servlet.DwrServlet</servlet-class>
      <init-param>
         <param-name>debug</param-name>
         <param-value>true</param-value>
      </init-param>
   </servlet>

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

   **说明:让给servlet处理所有/dwr/前缀开始的所有请求。
   
  3.配置DWR的配置文件dwr.xml(该文件可从war包中拷贝,放到项目的WEB-INF中,和web.xml位与同目录)
   
   <dwr>
      <allow>
         <create creator="new" javascript="service">
             <param name="class" value="com.lj.firstdwr.Service" />
         </create>
      </allow>
   </dwr>

   **说明:配置想要在浏览器js中调用的java类,一个<create>表示一个类的配置,
     javascript属性是浏览器中调用该类的变量名,即js中直接调用service的方法就是调用value属性指定的Service类中的方法
    
  4.编写刚配置的Service类:就是一个普通的java类,没有任何特殊的地方
    
   package com.lj.firstdwr;
   public class Service{ 
      public String sayHello(String name){ 
      //可以是访问数据库的复杂代码 
      return "Hello World! My Name is: " + name; 
      }
   }
    
  5.编写前台JSP通过js来调用Service类中的sayHello()方法
   
   **注意:
     A.此时要在JSP文件中引入上面加入到js目录中的两个js文件engine.js是必须的,util.js提供很多工具方法。
     B.因为要调用Service类,因为该类注册到dwr.xml配置文件中,
       那么DWR会在dwr/interface/(该目录是DWR规定的固定不变的)目录生成
       一个代表Service类的service.js文件(文件名和javascript="service"属性值相同),
       加入这个js文件后才可以通过js调用service变量操作Service类中的方法。

   <html>
    <head>
     //<script type="text/javascript" src="js/util.js"></script>
     //<script type="text/javascript" src="js/engine.js"></script>
     **注意:将js改成dwr,代表engine.js和util.js文件使用的是dwr.jar库中的文件,而不是自己导入的,如果使用自己导入的会有错!!
     <script type="text/javascript" src="dwr/util.js"></script>
     <script type="text/javascript" src="dwr/engine.js"></script>
     <script type="text/javascript" src="dwr/interface/service.js"></script>
     //编写JS文件调用Service类中的sayHello()方法
     <script type="text/javascript">
      function firstDwr(){
       //参数列表的除最后一个都是sayHello()方法的参数,最后一个参数DWR规定为设定回调函数
       service.sayHello("lijie",callBack); 
      }
      //回调函数
      function callBack(data){
       alert(data); 
      }
      /*
      这个等同于上边的两个方法的加合,这里就是把回调函数直接放到最后一个参数中最为一个匿名函数,这样比较简洁
      function firstDwr(){
       service.sayHello("lijie",
           function(data){
            alert(data); 
           }
       ); 
      }
      */
     </script>
    </head>

    <body>
     <!--触发JavaScript事件-->
     <input type="button" name="button" value="测试" onclick="firstDwr()">
    </body>
   </html>

分享到:
评论

相关推荐

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

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

    DWR学习笔记及经验总结

    在“DWR学习笔记及经验总结”中,我们可以期待找到以下关键知识点: 1. **DWR的基本概念**:了解DWR的核心理念,包括远程方法调用(Remote Method Invocation)、反向Ajax以及它如何通过JSON或XML格式传递数据。 2...

    dwr学习笔记pdf文件

    ### dwr学习笔记pdf文件知识点概述 #### 一、DWR框架简介 - **DWR**(Direct Web Remoting)是由GetAhead公司开发的一款用于实现Ajax应用的框架。该框架的核心价值在于允许客户端JavaScript直接调用服务器端Java类...

    dwr学习笔记和总结

    ### dwr学习笔记和总结 #### 一、DWR简介 DWR (Direct Web Remoting) 是一个简化Ajax开发的框架,它使得JavaScript能够直接调用服务器端的Java方法成为可能,无需编写复杂的Ajax代码。这极大地提高了开发效率,并...

    DWR学习笔记和与spring整合练习

    **DWR(Direct Web Remoting)**是一种JavaScript库,它允许Web...通过深入学习和实践"DWR学习笔记和与spring整合练习",开发者可以掌握DWR的精髓,熟练运用其与Spring的整合,打造出高效、安全、易维护的Web应用程序。

    DWR学习笔记-HelloWorld篇

    【标题】:“DWR学习笔记-HelloWorld篇” 在IT领域,DWR(Direct Web Remoting)是一个开源的Java框架,它允许JavaScript在浏览器端直接调用服务器端的Java方法,实现了网页与服务器的实时交互,类似于Ajax技术,但...

    dwr学习笔记(一个简单猜数字游戏)

    总结来说,这个"DWR学习笔记"示例涵盖了以下知识点: 1. DWR的基本概念和工作原理,包括Reverse Ajax机制。 2. 如何在服务器端配置DWR,定义可调用的Java服务。 3. 客户端如何使用DWR的JavaScript库与服务器进行通信...

    ajax dwr学习笔记和jar文件

    DWR (Direct Web Remoting) 是一个开源的Java库,它允许Web应用程序在客户端JavaScript和服务器端Java之间进行实时通信,无需刷新整个页面。DWR简化了Ajax(Asynchronous JavaScript and XML)应用的开发,使得...

    DWR学习笔记(下载)

    **DWR(Direct Web Remoting)学习笔记** DWR是一种Java技术,用于在浏览器和服务器之间实现双向通信,使得Web应用程序能够实时更新和交互。它允许JavaScript直接调用服务器端的Java方法,就像它们是本地函数一样,...

    DWR学习笔记

    **DWR(Direct Web Remoting)**是一种Java...总之,DWR学习笔记将引导你探索如何利用DWR、ExtJS和Spring构建高效、交互性强的Web应用。通过深入学习和实践,你将能够熟练运用这些工具和技术,提升你的Web开发能力。

    DWR的学习资料,DWR学习必备

    DWR使用笔记.chm:这可能是一份详细的DWR使用手册,包含了如何集成DWR到项目中、配置DWR引擎、创建远程接口以及处理各种交互的实例。通过阅读这份笔记,你可以了解到DWR的基本概念、配置步骤以及实际应用技巧。 dwr...

    DWR学习资料

    DWR学习资料 :DWR 3.0 上传文件.txt DWR3.0反向Ajax示例.txt DWR3.0学习笔记.txt DWR3.0学习网址.txt dwr分页.doc DWR分页代码.doc DWR中文文档.doc DWR中文文档.pdf dwr做comet的完整实现.doc Spring整合DWR comet ...

    DWR学习笔记(如何配置DWR和工程实例)

    DWR(Direct Web Remoting)是一种Java库,用于在Web应用程序中实现JavaScript和服务器端Java对象之间的双向通信。它使得动态、实时的Web界面成为可能,而无需刷新整个页面。以下是对DWR配置和工程实例的详细解释: ...

    dwr3 学习笔记<一>

    【标题】"dwr3 学习笔记&lt;一&gt;" 涉及的主要知识点是Direct Web Remoting (DWR)框架的第三版。DWR是一种Java库,它允许Web应用程序在客户端(通常是JavaScript)和服务器端(Java)之间进行实时通信,从而实现动态的、...

    DWR 2.0M3 学习笔记

    阅读"DWR学习笔记.doc"文件将有助于系统地掌握这些知识点,通过实践操作加深理解,从而更好地利用DWR构建交互性强、用户体验良好的Web应用。在学习过程中,结合源码分析可以更深入地理解DWR的工作机制,提升自己的...

    DWR实战学习笔记.txt

    技术分享:DWR实战学习笔记

Global site tag (gtag.js) - Google Analytics