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

dwr.xml配置描述及JSP上的引用DWR实现AJAX

    博客分类:
  • JS
阅读更多
下面的文章也不全是我整理的,最近在搞DWR,所以将机器上的文档翻了翻,觉得这个文档蛮有用的,特意贴出来大家分享分享,呵呵

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

1.1、dwr.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>标签指定要公开给javascript的java类名。

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

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



1.2、javascript中调用

首先,引入javascript脚本

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

其中TestClass.js是dwr根据配置文件自动生成的,engine.js和util.js是dwr自带的脚本

文件。

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

function callTestMethod1(){

      testClass.testMethod1();

}



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

2.1、dwr.xml的配置

配置同1.1

<dwr>

<allow>

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

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

<include method="testMethod2"/>

</create>

</allow>

</dwr>

2.2、javascript中调用

首先,引入javascript脚本

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

function callTestMethod2(){

      testClass.testMethod2(callBackFortestMethod2);

}

function callBackFortestMethod2(data){

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

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

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

}

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



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

3.1、dwr.xml的配置

配置同1.1

<dwr>

<allow>

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

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

<include method="testMethod3"/>

</create>

</allow>

</dwr>

3.2、javascript中调用

首先,引入javascript脚本

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

function callTestMethod3(){

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

      var data;

      //构造参数

      data = “test String”;

      testClass.testMethod3(data);

}



4、调用返回JavaBean的java方法

4.1、dwr.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自动地在

Java和JavaScript表示之间调整简单数据类型。这些类型包括Java原生类型和它们各

自的封装类表示,还有String、Date、数组和集合类型。DWR也能把JavaBean转换成   JavaScript 表示,但是出于安全性的原因,要求显式的配置,<convertor>标签就是完

成此功能的。

converter="bean"属性指定转换的方式采用JavaBean命名规范,

match=""com.dwr.TestBean"属性指定要转换的javabean名称,

<param>标签指定要转换的JavaBean属性。include指定要准换的属性,exclude表示不转           换的属性

4.2、javascript中调用

首先,引入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.1、dwr.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.2、javascript中调用

首先,引入javascript脚本

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

function callTestMethod5(){

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

      var data;

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

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

      testClass.testMethod5(data);

}



6、调用返回List、Set或者Map的java方法

6.1、dwr.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>

注意:如果List、Set或者Map中的元素均为简单类型(包括其封装类)或String、Date、

数组和集合类型,则不需要<convert>标签。

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

首先,引入javascript脚本

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

function callTestMethod6(){

      testClass.testMethod6(callBackFortestMethod6);

}

function callBackFortestMethod6(data){

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

//对于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、调用有List、Set或者Map参数的java方法

7.1、dwr.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>

<![CDATA[

import java.util.List;

import com.dwr.TestClass;

import com.dwr.TestBean;

TestClass.testMethod7(List<TestBean>);

]]>

</signatures>

</dwr>

<signatures>标签是用来声明java方法中List、Set或者Map参数所包含的确切类,以便java

代码作出判断。

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

首先,引入javascript脚本

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

function callTestMethod7(){

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

    var data;

    //构造参数,date实际上是一个object数组,即数组的每个元素均为object

data = [{

                    username:"user1",

                password:"password2"

           },

           {

                    username:"user2",

                password:" password2"

            }];

      testClass.testMethod7(data);

}

注意:

1、对于第6种情况,如果java方法的返回值为Map,则在接收该返回值的javascript回           调函数中如下处理:

function callBackFortestMethod(data){

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

           for(var property in data){

                  var bean = data[property];

                  alert(bean.username);

                  alert(bean.password);

           }

}

2、对于第7种情况,如果java的方法的参数为Map(假设其key为String,value为

TestBean),则在调用该方法的javascript函数中用如下方法构造要传递的参数:

function callTestMethod (){

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

        var data;

       //构造参数,date实际上是一个object,其属性名为Map的key,

               //属性值为Map的value

       data = {

             "key1":{

                  username:"user1",

                  password:"password2"

              },

              "key2":{

                   username:"user2",

                   password:" password2"

              }};

         testClass.testMethod(data);}

并且在dwr.xml中增加如下的配置段

<signatures>

<![CDATA[

import java.util.List;

import com.dwr.TestClass;

import com.dwr.TestBean;

TestClass.testMethod7(Map<String,TestBean>);

]]>

</signatures>

3、由以上可以发现,对于java方法的返回值为List(Set)的情况,DWR将其转化为Object

数组,传递个javascript;对于java方法的返回值为Map的情况,DWR将其转化为   一个Object,其中Object的属性为原Map的key值,属性值为原Map相应的value

4、如果java方法的参数为List(Set)和Map的情况,javascript中也要根据3种所说,构            造相应的javascript数据来传递到java中。



======================================================================

Scripting Introduction

DWR根据dwr.xml生成和Java代码类似的Javascript代码。

相对而言Java同步调用,创建与Java代码匹配的Ajax远程调用接口的最大挑战来至与实现Ajax的异步调用特性。

DWR通过引入回调函数来解决这个问题,当结果被返回时,DWR会调用这个函数。

有两种推荐的方式来使用DWR实现远程方法调用。可以通过把回调函数放在参数列表里,也可以把回调函数放到元数据对象里。

当然也可以把回调函数做为第一个参数,但是不建议使用这种方法。因为这种方法在处理自动处理http对象时(查看"Alternative Method")上会有问题。这个方法主要是为向下兼容而存在的。

简单的回调函数

假设你有一个这样的Java方法:

public class Remote

{   

public String getData(int index) { ... }

}

我们可以在Javascript中这样使用:

<script type="text/javascript" src="[WEBAPP]/dwr/interface/Remote.js"> </script>

<script type="text/javascript" src="[WEBAPP]/dwr/engine.js"> </script>...

function handleGetData(str)



alert(str);

}

Remote.getData(42, handleGetData);

42是Java方法getData()的一个参数。

此外你也可以使用这种减缩格式:

Remote.getData(42, function(str) { alert(str); });

调用元数据对象(Meta-Data)

另外一种语法时使用"调用元数据对象"来指定回调函数和其他的选项。上面的例子可以写成这样:

Remote.getData(42, {  callback:function(str) { alert(str); }});

这种方法有很多优点:易于阅读,更重要的指定额外的调用选项。

超时和错误处理

在回调函数的元数据中你可以指定超时和错误的处理方式。例如:

Remote.getData(42, {  callback:function(str) { alert(str); },  timeout:5000, 

errorHandler:function(message) { alert("Oops: " + message); }});

查找回调函数

有些情况下我们很难区分各种回调选项(记住,Javascript是不支持函数重载的)。例如:

Remote.method({ timeout:3 }, { errorHandler:somefunc });

这两个参数之一是bean的参数,另一个是元数据对象,但是我们不能清楚的告诉DWR哪个是哪个。为了可以跨浏览器,我们假定null == undefined。 所以当前的情况,规则是:

如果第一个或最后一个是一个函数,那么它就是回调函数,没有元数据对象,并且其他参数都是Java的方法参数。 

另外,如果最后一个参数是一个对象,这个对象中有一个callback成员,并且它是个函数,那么这个对象就是元数据对象,其他的都是Java方法参数。 

另外,如果第一个参数是 null ,我们就假设没有回调函数,并且其他的都是Java方法参数。尽管如此,我们会检查最后一个参数是不是null,如果是就发出警告。 

最后如果最后一个参数是null,那么就没有callback函数。 

另外,发出错误信号是个糟糕的请求格式。

创造一个与Java对象匹配的Javascript对象

假设你有这样的Java类:

public class Remote



public void setPerson(Person p)

{   

this.person = p; 

}

}

Person类的结构是这样的:

public class Person



private String name; 

private int age; 

private Date[] appointments; 

// getters and setters ...

}

那么你可以在Javascript中这样写:

var p = {  name:"Fred Bloggs",  age:42, 

appointments:[ new Date(), new Date("1 Jan        2008") ]};

Remote.setPerson(p);

在Javascript没有出现的字段,在Java中就不会被设置。

因为setter都是返回'void',我们就不需要使用callback函数了。如果你想要一个返回void的服务端方法的完整版,你也可以加上callback函数。很明显DWR不会向它传递任何参数。
分享到:
评论

相关推荐

    DWR.xml配置文件说明书(含源码)

    DWR.xml配置文件说明书 1、 建立dwr.xml 配置文件 任何一个dwr.xml的文件都需要包含DWR DOCTYPE的声明行,格式如下: &lt;!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 1.0//EN" ...

    葵花宝典之js、ajax、dwr.pdf

    JavaScript、Ajax、DWR相关知识点总结 一、JavaScript与Java的区别 1. 编程语言类型:JavaScript是一种基于对象的脚本语言,而Java是一种面向对象的编程语言。 2. 执行方式:JavaScript是通过浏览器解释执行的,而...

    struts自我学习过程程序以及说明

    配置dwr.xml和web.xml 运行 http://localhost:5858/start/dwr/ 它会在后台输出一些信息,自己看一下就可以了,就是一些加载项之类的东西或者是其他的一些信息. ajaxvalidate包 AjaxValidation.jsp 配置struts.xml即可...

    DWR中文文档.pdf

    web.xml配置 13 2.1 主要配置 13 2.2 常用参数列表 14 2.2.1 安全参数 14 2.2.2 Ajax服务器加载时保护参数 14 2.2.3 其他参数 15 2.3 日志配置 16 2.4 多个dwr.xml配置和J2EE角色定义 ...

    DWR所有jar包和两个简单交互例子

    DWR是一个用于改善web页面与Java类交互的远程服务器端Ajax开源框架...我做了两个简单的例子,项目中web.xml,dwr.xml,DwrPush.java,DwrPush2.java,dwrDemo.jsp。还有所需要的所有jar包,一看就会,放到eclipse就能运行。

    xml学习笔试,超级好

    12_ajax_ext_dwr.rar; 13_ooad&uml.rar; 14_javascript.rar; 15_ejb.rar; 16_spring.rar; 17_cvs.rar; 18_pl_sql.rar 需要下载的话,请输入相应关键字,便可搜到。 觉得好的话,支持我,我还会上传更多好的...

    采用ajax实现的图片验证码

    采用ajax技术实现的图形验证码,在前端进行验证。验证码信息为图片。每一行代码均有注释,通俗易懂。 实现步骤: 1、创建web工程 2、在jsp页面,编写一个请求servlet的名称"&gt; 3、编写一个servlet,在servlet中产生...

    2_corejava_tiger.rar

    12_ajax_ext_dwr.rar; 13_ooad&uml.rar; 14_javascript.rar; 15_ejb.rar; 16_spring.rar; 17_cvs.rar; 18_pl_sql.rar 需要下载的话,请输入相应关键字,便可搜到。 觉得好的话,支持我,我还会上传更多好的...

    Unix学习笔试,超级好,1_unix.rar

    12_ajax_ext_dwr.rar; 13_ooad&uml.rar; 14_javascript.rar; 15_ejb.rar; 16_spring.rar; 17_cvs.rar; 18_pl_sql.rar 需要下载的话,请输入相应关键字,便可搜到。 觉得好的话,支持我,我还会上传更多好的...

    jsp qq 校友录

    共享文件,通讯录,显示成员资料,搜索成员,用户可以编辑资料,支持上传用户头像,好友列表,以及支持传纸条功能,程序采用jsp编程,使用了dwr,ajax框架, 以及servlet..数据库使用MS SQL2005(jsp程序访问数据库的...

    纯JSP+DWR实现三级联动下拉选择菜单实现技巧

    今天我做了一个dwr+jsp做的例子。 web.xml: 代码如下: &lt;?xml version=”1.0″ encoding=”UTF-8″?&gt; &lt;web-app version=”2.4″ xmlns=”http://java.sun.com/xml/ns/j2ee” xmlns:xsi=”...

    dwr+jsp+sqlserver2000无刷新分页

    在网上找到大量的关于ajax分页技术,看了大部分都是用mysql数据库,再者就是用解析xml文件来实现的,(太难了吧),现在这个分页的例子很简单的, 先说说我认为的优点吧: 1、实现简单(js算),业务简单(没有用到...

    Jetty中文手册

    配置Ajax、Comet和异步Servlets 持续和异步Servlets 100 Continue和102 Processing WebSocket Servlet 异步的REST Stress Testing CometD 使用Servlets和Filters Jetty中绑定的Servlets Quality of Service Filter ...

    Professional Ajax

    Chapter 4: "XML, XPath, and XSLT." This chapter introduces XML, XPath, and XSLT as complementary technologies to Ajax. The discussion centers on using XML as a data transmission format...

    java开发者必用的插件,搜索JSmart_1.3.1.jar(寻觅插件)然后下载

    可以快速构建JSP列表页面. &lt;br&gt; 主要功能: 1、SSH框架一键配置 2、JSP列表标签导入及JSP页面列表快速生成(内置两套开源标签) 3、AJAX框架两套EXT2及DWR框架快速导入 4、HTML在线编辑器一键导入...

    java技术员必下的最强大的插件,搜索JSmart_1.3.1.jar(寻觅插件)然后下载

    可以快速构建JSP列表页面. &lt;br&gt; 主要功能: 1、SSH框架一键配置 2、JSP列表标签导入及JSP页面列表快速生成(内置两套开源标签) 3、AJAX框架两套EXT2及DWR框架快速导入 4、HTML在线编辑器一键导入...

    低清版 大型门户网站是这样炼成的.pdf

    2.2.1 web.xml中struts 2的配置实现 54 2.2.2 struts 2属性配置文件struts.properties详解 55 2.2.3 struts 2核心配置文件struts.xml详解 57 2.3 struts 2应用开发实务 61 2.3.1 struts 2应用开发环境的搭建 62 ...

    非常苛刻的java工作要求

    3. 熟悉各种Web前端技术,包括JavaScript、CSS、HTML4/5、(XHTML、XML、Ajax)、json、jstl、JQuery,jsp,对DWR、Bootstrap、EasyUI、DWZ、ExtJS有一定了解; 4. 熟悉Extjs,dojo,easyUI等及有相关项目开发经验者...

    java培训上课资料pdf

    在13年培训java课程的全部笔记都在这了。JavaSE/JavaEE:熟悉Swing、JDBC编程,了解Socket、多线程以及反射...网页相关:能熟练运用Web2.0技术,如:AJAX及DWR等AJAX框架及服务器推技术和HTML、JavaScript、CSS等技术。

Global site tag (gtag.js) - Google Analytics