`
benx
  • 浏览: 276337 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Dwr总结 转

    博客分类:
  • java
阅读更多

DWR是一个框架,简单的说就是能够在javascript直接调用java方法,而不必去写一大堆的javascript代码。它的实现是基于ajax的,可以实现无刷新效果。

    网上有不少DWR的例子,但大都只是某种方法的调用,本文只在使用层面上介绍DWR,并不涉更多的技术与设计,其目的是让初学者能够很快的学会各种java方法在javascript中是如何调用的。

    本文以DWR 1.1 为基础,对于DWR 2.0,因为还没有正式发布版,故不做介绍。

一、dwr配置web.xml

   1、最小配置

<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>
</servlet-mapping>
2、当我们想看DWR自动生成的测试页(Using debug/test mode)时,可在servlet配置中加上

<init-param>
 
 <param-name>debug</param-name>
 
 <param-value>true</param-value>
</init-param>

这个参数DWR默认是false。如果选择true,我们可以通过http://localhost:port/app/dwr看到你部署的每个DWR class。并且可以测试java代码的每个方法是否运行正常。为了安全考虑,在正式环境下你一定把这个参数设为false

3、多个dwr.xml文件的配置

可能有几种情况,我们一一列举。一个servlet,多个dwr.xml配置文件;多个servlet,每个servlet对应一个或多个dwr.xml配置文件。

3.1、一个servlet,多个dwr.xml配置文件

<servlet>
 
   <servlet-name>dwr-invoker</servlet-name>
 
   <servlet-class>uk.ltd.getahead.dwr.DWRServlet</servlet-class>
 
   <init-param>
 
     <param-name>config-1</param-name>
 
     <param-value>WEB-INF/dwr1.xml</param-value>
 
   </init-param>
 
   <init-param>
 
     <param-name>config-2</param-name>
 
     <param-value>WEB-INF/dwr2.xml</param-value>
 
   </init-param>
</servlet>

在这种配置下,param-name的值必须以config开头。param-name可以有>=0个。如果没有param-name,那么将会读取WEB-INF/dwr.xml。如果有大于零个param-name,那么WEB-INF/dwr.xml文件将不会被读取。

3.2、多个servlet,每个servlet对应一个或多个dwr.xml

<servlet>
 
  <servlet-name>dwr-invoker</servlet-name>
 
   <servlet-class>uk.ltd.getahead.dwr.DWRServlet</servlet-class>
</servlet>
<servlet>
 
  <servlet-name>dwr-invoker1</servlet-name>
 
  <servlet-class>uk.ltd.getahead.dwr.DWRServlet</servlet-class>
 
  <init-param>
 
    <param-name>config-admin</param-name>
 
    <param-value>WEB-INF/dwr1.xml</param-value>
 
  </init-param>
 
  <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-mapping>
 
  <servlet-name>dwr-invoker1</servlet-name>
 
  <url-pattern>/dwr1/*</url-pattern>
</servlet-mapping>

在这种情况下,我们可以根据J2EE security来控制权限,针对不同url,加不同的角色。

 

 

二、dwr使用

1、调用没有返回值和参数的JAVA方法

1.1dwr.xml的配置

<dwr>

<allow>

<create creator="new" javascript="testClass" >

<param name="class" value="com.dwr.TestClass" />

<include method="testMethod1"/>

</create>

</allow>

</dwr>

<allow>标签中包括可以暴露给javascript访问的东西。

<create>标签中指定javascript中可以访问的java类,并定义DWR应当如何获得要进行远程的类的实例。creator="new"属性指定java类实例的生成方式,new意味着DWR应当调用类的默认构造函数来获得实例,其他的还有spring方式,通过与IOC容器Spring进行集成来获得实例等等。javascript=" testClass "属性指定javascript代码访问对象时使用的名称

<param>标签指定要公开给javascriptjava类名。

<include>标签指定要公开给javascript的方法。不指定的话就公开所有方法。

<exclude>标签指定要防止被访问的方法。

1.2javascript中调用

首先,引入javascript脚本

<script src='dwr/interface/ testClass.js'></script>

<script src='dwr/engine.js'></script>

<script src='dwr/util.js'></script>

其中TestClass.jsdwr根据配置文件自动生成的,engine.jsutil.jsdwr自带的脚本文件。

其次,编写调用java方法的javascript函数

Function callTestMethod1(){

      testClass.testMethod1();

}

 

2、调用有简单返回值的java方法

2.1dwr.xml的配置

配置同1.1

<dwr>

<allow>

<create creator="new" javascript="testClass" >

<param name="class" value="com.dwr.TestClass" />

<include method="testMethod2"/>

</create>

</allow>

</dwr>

2.2javascript中调用

首先,引入javascript脚本

其次,编写调用java方法的javascript函数和接收返回值的回调函数

Function callTestMethod2(){

      testClass.testMethod2(callBackFortestMethod2);

}

Function callBackFortestMethod2(data){

     //其中date接收方法的返回值

     //可以在这里对返回值进行处理和显示等等

alert("the return value is " + data);

}

其中callBackFortestMethod2是接收返回值的回调函数

3、调用有简单参数的java方法

3.1dwr.xml的配置

配置同1.1

<dwr>

<allow>

<create creator="new" javascript="testClass" >

<param name="class" value="com.dwr.TestClass" />

<include method="testMethod3"/>

</create>

</allow>

</dwr>

3.2javascript中调用

首先,引入javascript脚本

其次,编写调用java方法的javascript函数

Function callTestMethod3(){

                 //定义要传到java方法中的参数

      var data;

      //构造参数

      data = “test String”;

      testClass.testMethod3(data);

}

4、调用返回JavaBeanjava方法

4.1dwr.xml的配置

<dwr>

<allow>

<create creator="new" javascript="testClass" >

<param name="class" value="com.dwr.TestClass" />

<include method="testMethod4"/>

</create>

<convert converter="bean" match=""com.dwr.TestBean">

                  <param name="include" value="username,password" />

</convert>

</allow>

</dwr>

<creator>标签负责公开用于Web远程的类和类的方法,<convertor>标签则负责这些方法的参数和返回类型。convert元素的作用是告诉DWR在服务器端Java 对象表示和序列化的JavaScript之间如何转换数据类型。DWR自动地在JavaJavaScript表示之间调整简单数据类型。这些类型包括Java原生类型和它们各自的封装类表示,还有StringDate、数组和集合类型。DWR也能把JavaBean转换成JavaScript 表示,但是出于安全性的原因,要求显式的配置,<convertor>标签就是完成此功能的。converter="bean"属性指定转换的方式采用JavaBean命名规范,match=""com.dwr.TestBean"属性指定要转换的javabean名称,<param>标签指定要转换的JavaBean属性。

4.2javascript中调用

首先,引入javascript脚本

其次,编写调用java方法的javascript函数和接收返回值的回调函数

Function callTestMethod4(){

      testClass.testMethod4(callBackFortestMethod4);

}

Function callBackFortestMethod4(data){

     //其中date接收方法的返回值

//对于JavaBean返回值,有两种方式处理

             //不知道属性名称时,使用如下方法

           for(var property in data){

              alert("property:"+property);

              alert(property+":"+data[property]);

           }

//知道属性名称时,使用如下方法

           alert(data.username);

           alert(data.password);

}

其中callBackFortestMethod4是接收返回值的回调函数

5、调用有JavaBean参数的java方法

5.1dwr.xml的配置

配置同4.1

<dwr>

<allow>

<create creator="new" javascript="testClass" >

<param name="class" value="com.dwr.TestClass" />

<include method="testMethod5"/>

</create>

<convert converter="bean" match="com.dwr.TestBean">

                  <param name="include" value="username,password" />

</convert>

</allow>

</dwr>

5.2javascript中调用

首先,引入javascript脚本

其次,编写调用java方法的javascript函数

Function callTestMethod5(){

                 //定义要传到java方法中的参数

      var data;

      //构造参数,date实际上是一个object

      data = { username:"user", password:"password" }

      testClass.testMethod5(data);

}

6、调用返回ListSet或者Mapjava方法

6.1dwr.xml的配置

配置同4.1

<dwr>

<allow>

<create creator="new" javascript="testClass" >

<param name="class" value="com.dwr.TestClass" />

<include method="testMethod6"/>

</create>

<convert converter="bean" match="com.dwr.TestBean">

<param name="include" value="username,password" />

</convert>

</allow>

</dwr>

注意:如果ListSet或者Map中的元素均为简单类型(包括其封装类)或StringDate、数组和集合类型,则不需要<convert>标签。

6.2javascript中调用(以返回List为例,List的元素为TestBean)

首先,引入javascript脚本

其次,编写调用java方法的javascript函数和接收返回值的回调函数

Function callTestMethod6(){

      testClass.testMethod6(callBackFortestMethod6);

}

Function callBackFortestMethod6(data){

     //其中date接收方法的返回值

//对于JavaBean返回值,有两种方式处理

             //不知道属性名称时,使用如下方法

           for(var i=0;i<data.length;i++){

for(var property in data){

                  alert("property:"+property);

                  alert(property+":"+data[property]);

               }

}

//知道属性名称时,使用如下方法

for(var i=0;i<data.length;i++){

               alert(data.username);

               alert(data.password);

}

}

 

7、调用有ListSet或者Map参数的java方法

7.1dwr.xml的配置

<dwr>

<allow>

<create creator="new" javascript="testClass" >

<param name="class" value="com.dwr.TestClass" />

<include method="testMethod7"/>

</create>

<convert converter="bean" match="com.dwr.TestBean">

<param name="include" value="username,password" />

</convert>

</allow>

<signatures>

left

分享到:
评论

相关推荐

    Ajax的dwr总结

    DWR (Direct Web Remoting) 是一种开源JavaScript库,它允许Web应用程序在客户端与服务器之间进行实时、异步通信,无需刷新整个页面。Ajax(Asynchronous JavaScript and XML)技术是DWR实现其功能的基础,通过Ajax...

    关于dwr简单设计总结

    以下是对DWR简单设计的总结: 1. **DWR的基本概念**: DWR的核心功能是在客户端JavaScript和服务器端Java之间建立直接的通信通道,通过AJAX(Asynchronous JavaScript and XML)技术实现异步数据交换。这允许用户...

    DWR中处理集合总结

    在DWR(Direct Web Remoting)中,处理集合是一项关键任务,因为它允许JavaScript与服务器端的Java代码进行交互,传递和接收数据集合。DWR是一个开源框架,它使得Web应用程序可以利用Ajax技术实现异步通信,即在不...

    dwr笔记 dwr自学资料

    总结来说,DWR是一种强大的工具,能够帮助开发者构建出更加高效、响应式的Web应用。通过学习和掌握DWR,你可以更好地融合前后端开发,实现更为流畅的用户交互。在自学过程中,理解DWR的工作原理、熟练运用其主要组件...

    DWR配置文件详解,DWR配置

    总结起来,DWR的`dwr.xml`配置文件是实现JavaScript与Java之间交互的核心,它详细定义了哪些Java对象可以被JavaScript访问,以及如何进行数据转换。理解和配置好`dwr.xml`文件对于充分利用DWR的功能至关重要,同时也...

    dwr2.0 dwr3.0 jar包

    总结起来,DWR是一个强大的工具,通过提供JavaScript与Java之间的无缝交互,极大地简化了Ajax应用的开发。无论是DWR 2.0还是3.0,它们都为Java开发者提供了高效、灵活的解决方案,帮助构建更加动态、响应式的Web界面...

    DWR中文文档 (DWR 2.0)

    5. **本节总结**:概括上述JavaScript高级特性的应用技巧,以及它们如何帮助开发者更高效地使用DWR。 通过以上内容,我们可以看到DWR不仅是一个强大的框架,还提供了一系列实用的工具和资源来帮助开发者构建高性能...

    ajax的dwr包

    总结起来,DWR是一个强大的工具,它简化了Ajax开发,提供了丰富的功能和良好的安全性,使得开发者能够更加专注于业务逻辑的实现,而不是技术细节。如果你正在寻找一种方式来增强你的Web应用的交互性和响应速度,DWR...

    dwr学习笔记和总结

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

    DWR技术文档、快速使用DWR、java技术

    **总结** DWR作为Java世界中的一个强大工具,极大地简化了AJAX开发,使得JavaScript能够轻松地与服务器进行通信。通过理解其核心功能、配置步骤以及使用流程,开发者可以快速地在项目中引入DWR,构建高效、动态的...

    dwr_demo_test

    总结起来,DWR是实现客户端和服务器端高效通信的工具,通过`dwr_demo_test`,你可以学习到如何在实际项目中运用DWR,提升Web应用的交互性和用户体验。通过深入研究`dwr.xml`配置、Java服务端代码以及JavaScript调用...

    Spring与DWR集成

    总结,Spring与DWR的集成使得开发高效、实时的Web应用变得更加便捷。通过这种方式,开发者可以充分利用Spring的灵活性和DWR的实时通信能力,构建出更符合现代Web需求的应用。在实际项目中,理解并掌握这种集成技术...

    DWR网页聊天例子

    总结来说,"DWR网页聊天例子"展示了如何利用DWR这一强大的工具来构建实时交互的Web应用程序。通过理解DWR的工作原理和实践,开发者可以创建更富于动态性和交互性的网页应用,提升用户体验。无论是初学者还是经验丰富...

    采用dwr技术实现的聊天室

    总结,通过这个简单的DWR聊天室实例,我们可以了解到DWR在实现动态Web应用中的重要作用,以及如何使用DWR来构建实时交互的Web系统。对于希望提升Web开发技能的开发者来说,深入学习DWR是一个值得投入的方向。

    DWR的使用方法

    **总结** DWR作为一种强大的工具,简化了AJAX开发,让前端开发者可以直接使用JavaScript调用服务器端的Java方法。通过理解其核心组件、安装配置、创建远程接口、配置DWR以及使用JavaScript API,你就能在自己的项目...

    远程调用dwr.zip

    总结来说,DWR是实现Ajax应用的一个强大工具,它简化了前后端的通信,提高了Web应用的响应速度和用户体验。通过深入学习和实践"远程调用dwr.zip"中的内容,你可以更好地掌握DWR的使用,并将其应用于你的项目中,提升...

    spring mvc 自动注入+dwr

    总结,Spring MVC 的自动注入简化了对象之间的依赖关系管理,而 DWR 提供了与服务器交互的能力,两者结合可以在不刷新页面的情况下实现动态数据更新,提升用户体验。在实际开发中,理解并熟练运用这些技术能有效提高...

    DWR使用总结

    5. **结果转换**:返回结果如果是自定义Bean,通过配置的转换器转成JSON字符串,响应给前端。 6. **数据接收**:前端通过回调函数接收并处理返回的数据。 **DwrServlet初始化参数**: DWR的Servlet可以通过初始化...

Global site tag (gtag.js) - Google Analytics