首先导入项目所需要的包,如下:dwr.jar,commons-logging-1.0.4.jar,版本可以调整

1.web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="2.4"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee   http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">

<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>
   <load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
   <servlet-name>dwr-invoker</servlet-name>
   <url-pattern>/dwr/*</url-pattern>
</servlet-mapping>

</web-app>

2.DWRTest.java
package com.micro;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

@SuppressWarnings("unchecked")
public class DWRTest {

/**
   * 第一个简单调用
   */
public String getStr() {
    return "第一个dwr示例,调用成功";
}

/**
   * 带传递参数的调用,返回String
   */
public String getInfo(String name, int age, String address) {
    return "我的名字叫" + name + ",现年" + age + "岁," + "来自" + address;
}

/**
   * 返回数组Array
   */
public String[] getStrArray() {
    return new String[] { "one", "two", "three", "go!" };
}

/**
   * 返回集合List
   */
public List getList() {
    List list = new ArrayList();
    list.add("welcome");
    list.add("to");
    list.add("BeiJing");
    return list;
}

/**
   * 返回Map类型
   */
public Map getMap() {
    Map map = new HashMap();
    map.put("name", "周星星");
    map.put("hobby", "逃课");
    return map;
}

/**
   * 返回二维数组类型
   */
public List getArrayList() {
    List list = new ArrayList();
    list.add(new String[] { "1", "2", "3" });
    list.add(new String[] { "one", "two", "three", "four", "five" });
    return list;
}

/**
   * Exception处理
   */
public List getListTest(List list) {
    try {
      list.get(0);
    } catch (Exception e) {
      throw new NullPointerException("数据位空");
    }
    return list;
}

}

3.dwr.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE dwr PUBLIC
    "-//GetAhead Limited//DTD Direct Web Remoting 2.0//EN"
    "http://getahead.org/dwr/dwr20.dtd">

<dwr>
<allow>
   <!-- 调用不同的方法,返回不同的数据类型 -->
   <create javascript="dwr" creator="new">
    <param name="class" value="com.micro.DWRTest" />
   </create>

<!-- 类型转换为JavaBean的处理 -->
   <create javascript="dwrBean" creator="new" scope="request">
    <param name="class" value="com.micro.UserRs" />
   </create>
   <convert match="com.micro.User" converter="bean">
    <param name="include" value="name,pass" />
   </convert>

<!-- 异常Exception的处理 ,默认情况下dwr对异常的处理就是一个弹出框提示为Error-->
   <create javascript="dwrException" creator="new">
    <param name="class" value="com.micro.DWRTest" />
   </create>
<convert match="java.lang.NullPointerException" converter="exception" />

</allow>

</dwr>

4.mydwr.js
/**
* 无参数
*/
function invoke1(){
dwr.getStr(
   function(value){
    alert(value);
   }
);
}

/**
* 有参数
*/
function invoke2(){
dwr.getInfo("长江七号",3,"火星",
   function(value){
    alert(value);
   }
);
}

/**
* 返回数组
*/
function invoke3(){
dwr.getStrArray(
   function(array){
    var str="";
    for(var i=0;i<array.length;i++){
     str += array[i]+" ";
    }
    alert(str);
   }
);
}

/**
* 返回集合(集合和数组的处理方式一样)
*/
function invoke4(){
dwr.getList(
   function(list){
    var str="";
    for(var i=0;i<list.length;i++){
     str += list[i];
    }
    alert(str);
   }
);
}
/**
* 返回Map
*/
function invoke5(){
dwr.getMap(

//有如下两种处理方式
   /*1)已知map的key*/
   function(map){
    alert("姓名:"+map.name+",爱好:"+map.hobby);
   }
   /*2).遍历的方式
    function(map){
    for(var key in map){
     alert(key+":"+map[key]);
    }
   }*/
);
}

/**
* 返回数组的集合(二维数组)
*/
function invoke6(){
dwr.getArrayList(
   function(arrayList){
    var str="";
    for(var i=0;i<arrayList.length;i++){
     for(var j=0;j<arrayList[i].length;j++){
      str += arrayList[i][j];
     }
     str+="\n\r";
    }
    alert(str);
   }
);
}

/**
* 同步设置
*/
function invoke7(){
dwr.engine.setAsync(false);//设置同步,那么后续的方法才能按照顺序执行
invoke1();
invoke2();
}

/**
* 批处理batch(按照先后顺序执行)
*/
function invoke8(){
dwr.engine.beginBatch();
invoke1();
invoke2();
dwr.engine.endBatch();
}

5.index.jsp
<%@ page language="java" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
   <script type='text/javascript' src='dwr/engine.js'></script>
   <script type='text/javascript' src='dwr/util.js'></script>
   <script type='text/javascript' src='dwr/interface/dwr.js'></script>
   <script type="text/javascript" src="mydwr.js"></script>
</head>

<body>
   <input type="button" value="DRW1" onclick="invoke1()" />
   <br />
   <input type="button" value="DRW2" onclick="invoke2()" />
   <br />
   <input type="button" value="DRW3" onclick="invoke3()" />
   <br />
   <input type="button" value="DRW4" onclick="invoke4()" />
   <br />
   <input type="button" value="DRW5" onclick="invoke5()" />
   <br />
   <input type="button" value="DRW6" onclick="invoke6()" />
   <br />
   <input type="button" value="DRW7" onclick="invoke7()" />
   <br />
   <input type="button" value="批处理测试" onclick="invoke8()" />
</body>
</html>

上述,index.jsp页面就对上述各种dwr的返回类型和批处理(batch)做了处理,做了简单的测试,Ok,测试通过,下面再介绍几个页面,
对dwr其他功能的一些简单测试:

6.异常处理:exception.jsp
<%@ page language="java" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
   <script type='text/javascript' src='dwr/engine.js'></script>
   <script type='text/javascript' src='dwr/util.js'></script>
   <script type='text/javascript' src='dwr/interface/dwrException.js'></script>
   <script type="text/javascript" src="mydwr.js"></script>
 
   <script type="text/javascript">
    function convert(){
     var list;
     dwrException.getListTest(list,
      {
       exceptionHandler:function(msg){
        alert(msg);
       },
       callback:function(data){
        alert(data);
       }
      }
     );
    }
  
   </script>
</head>

<body>
   <input type="button" value="异常测试" onclick="convert()"/>
</body>
</html>

7.dwr.util.getValue()调用,dwrfunc.jsp
<%@ page language="java" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
   <script type='text/javascript' src='dwr/engine.js'></script>
   <script type='text/javascript' src='dwr/util.js'></script>
   <script type='text/javascript' src='dwr/interface/dwr.js'></script>
   <script type="text/javascript" src="mydwr.js"></script>
</head>

<body>
   <input type="text" name="name" id="nameid" />
   <br/>
   <input type="button" value="EL通过id取值" onclick="alert(${'nameid'}.value)" />
   <br />
 
   //如果要是有dwr.util提供的功能,必须引入dwr/util.js文件,dwr3之后,有写函数内写name或id都可以
   <br/>
   <input type="button" value="dwr.util通过id" onclick="alert($('nameid').value)" />
   <br />
   <input type="button" value="dwr.util通过name" onclick="alert($('name').value)" />
   <br />
   <input type="button" value="dwr.util通过name/id" onclick="alert(dwr.util.getValue('name'))" />
   <br />

</body>
</html>

8.对JavaBean的传递和返回
User.java:
package com.micro;

public class User {

private String name;;
private String pass;

//get/set方法....
}

UserRs.java:
package com.micro;

public class UserRs {

public User convertUser(User user) {
    user.setName("admin");
    user.setPass("123456");
    return user;
}
}
bean.jsp:
<%@ page language="java" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
   <script type='text/javascript' src='dwr/engine.js'></script>
   <script type='text/javascript' src='dwr/util.js'></script>
   <script type='text/javascript' src='dwr/interface/dwrBean.js'></script>
   <script type="text/javascript" src="mydwr.js"></script>
 
   <script type="text/javascript">
    function convert(){
     var uname = $("name").value;
     var upass = $("pass").value;
     var obj = {name:uname,pass:upass};
   
     dwrBean.convertUser(obj,function(data){
      $("uname").value = data.name;
      $("upass").value = data.pass;
     });
    }
  
   </script>
</head>

<body>
   <input type="text" name="name" id="uname" value="you name"/><br/>
   <input type="text" name="pass" id="upass" value="your password"/><br/>
   <input type="button" value="测试处理" onclick="convert()"/>
</body>
</html>

这些,只是对dwr的简单应用,其中的配置都在dwr.xml中,大家可以举一反三,通常情况下,dwr和spring要结合使用,下面给出一个简单的配置说明:
比如:
<!-- 验证登陆名是否存在 -->
<create creator="spring" javascript="loginServiceDWR" scope="request">
   <param name="beanName" value="coreLoginService" />
   <include method="checkLogin" />
</create>
其中,creator="spring",表明由spring来创建该对象,javascript="loginServiceDWR",说明客户端的调用名称叫"loginServiceDWR",<param name="beanName" value="coreLoginService" />指明了spring配置文件中,id为"coreLoginService"的这么一个bean,<include method="checkLogin" />,对外公开的方法是"checkLogin" ,调用过程同上述其他类型调用相同,不同就是配置而已。上述代码,仅供参考。

注意:引入dwr的js文件的顺序不能错了,如:

<script type='text/javascript' src='dwr/engine.js'></script>
   <script type='text/javascript' src='dwr/util.js'></script>
   <script type='text/javascript' src='dwr/interface/dwrBean.js'></script>

先引入dwr自身的,再引入自己的。

DWR3.0 dwr 返回值(数组,集合,Map)的更多相关文章

  1. CXF2.7整合spring发布webservice,返回值类型是Map和List<Map>类型

    在昨天研究了发布CXF发布webservice之后想着将以前的项目发布webservice接口,可是怎么也发布不起来,服务启动失败,原来是自己的接口有返回值类型是Map. 研究了一番之后,发现: we ...

  2. 关于malloc(0)的返回值问题--这两天的总结与实践篇

    就像我在http://www.cnblogs.com/wuyuegb2312/p/3219659.html 文章中评论的那样,我也碰到了被提问这个malloc(0)的返回值问题,虽然感觉这样做在实际中 ...

  3. js返回值 数组去重

    function myfun(arr){ var arr1 = new Array(); var len = arr.length; ;i <len ;i++){ ) { arr1.push(a ...

  4. mybatis 返回值类型是Map

    <select id="selectByMemberKey" resultType="java.util.HashMap"> SELECT memb ...

  5. MyBatis3_[tp-26-27]_映射文件_select_返回List_记录封装Map:返回单个元素的Map或者整体Map集合

    笔记要点出错分析与总结工程组织 1.定义接口 public interface EmployeeMapper { //多条记录封装到一个map中: Map<Integer,Employee> ...

  6. JS数组方法的的返回值和是否改变该数组总结

    concat() 方法 concat() 方法用于连接两个或多个数组. 该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本. 返回值 返回一个新的数组.该数组是通过把所有 arrayX 参数添 ...

  7. libusb_bulk_transfer返回值不是0

    libusb_bulk_transfer返回值不是0 libusb_bulk_transfer返回值不是0libusb_bulk_transfer返回值不是0 ?????

  8. MyBatis中Mapper的返回值类型

    insert.update.delete语句的返回值类型 对数据库执行修改操作时,数据库会返回受影响的行数. 在MyBatis(使用版本3.4.6,早期版本不支持)中insert.update.del ...

  9. java基础35 双例集合Map及其常用方法

    单例集合体系: ---------| collection  单例集合的根接口--------------| List  如果实现了list接口的集合类,具备的特点:有序,可重复       注:集合 ...

随机推荐

  1. DiskFileItemFactory类---分析及运用

    DiskFileItemFactory类 将请求消息实体中的每一个项目封装成单独的DiskFileItem (FileItem接口的实现) 对象的任务由 org.apache.commons.file ...

  2. Eclipse问题解决集

    1.tomcate 报 PermGen space 错误Exception in thread "main" java.lang.OutOfMemoryError: PermGen ...

  3. 如何让Asp.net Web Api全局预防Xss攻击

    一.概述 二.什么是XSS 三.预防方法 四.在WebApi中如何实现 在实现之前,需要了解ASP.NET WEB API的pipeline机制. 如上,可以采用多种方式进行参数的过滤 1.重写Del ...

  4. 心情符号love

    写点什么呢,先谢谢心情吧,算是第一个脚印了,想先把之前的一些笔记和心得迁移进来吧,以后每个月都要充实自己的知识.向大婶们看齐.走你们走过的脚印,看你们前行的身影.沿着你们留下的路,继续为后者拓宽道路. ...

  5. 【BZOJ】【3676】【APIO2014】回文串

    回文自动机/Manacher+SA 这道题可以用Manacher找出本质不同的回文串(令max增大的所有回文串),然后再用SA跑出来有多少相同. 还有一种做法就是回文自动机(Orz Hzwer)的裸题 ...

  6. 关于High-Resolution Timer(了解)

    如果一个系统包含高精度性能计数器(HRPC,high-resolution performance counter)则此系统提供高精度定时器.你可以使用API函数QueryPerformanceFre ...

  7. DSP中常用的C语言关键字

    const Ø使用:const 数据类型 变量名: Ø作用:优化存储器的分配,表示变量的内容是常数,不会改变. Ø举例:const char tab[1024]={显示数据}; volatile(易变 ...

  8. uitableviewcell 和 uibutton

    如果cell上面只有一个button  可以设置button.tag=IndexPath.Row;得到当前点击的行数,设置button属性的时候,可以设置一个全局的button来记住当前点击的butt ...

  9. APM终端用户体验监控分析(下)

    一.前言 [APM 终端用户体验监控分析(上)][1]从 APM 终端用户产品特性.使用建议.以及从[真实用户体验][2]和[模拟性能监控][3]两方面入手给大家进行了简单的分享. 本文为下篇,将给大 ...

  10. ASP.NET 处理get/post数据方式

    1.GET方式 NameValueCollection coding; coding = HttpUtility.ParseQueryString(Request.Url.Query, Encodin ...