交易系统中有用到dwr,我们今天来看下。
DWR(Direct Web Remoting)是一个用于改善web页面与Java类交互的远程服务器端Ajax开源框架,可以帮助开发人员开发包含AJAX技术的网站。它可以允许在浏览器里的代码使用运行在WEB服务器上的JAVA函数,就像它就在浏览器里一样。
DWR框架主要包括如下两个部分。
1) 客户端有JavaScipt,这部分代码使客户端JavaScript可以直接调用远程服务器的Java方法。除此之外,DWR还提供了一些方便的工具函数来简化DOM操作。
2) 服务器上运行的Servlet负责处理用户请求,并将用户请求委托到实际Java对象进行处理,并负责把处理结果返回客户端。
基本原理是:当开发者直接调用远程Java方法时,DWR会负责将这种调用转换成对应的Ajax请求,并使用XMLHttpRequest将请求发送到远程服务端。当服务器处理完成后,DWR负责数据的传递和转换。
---------------------------------------------------以下练习 来自网友案例 感谢,侵删。-------------------------------------------------------
1.web.xml配置
成功安装DWR需要先修改web.xml文件,修改web.xml文件能保证特定请求被转发DWR的核心Servlet处理,而dwr.xml文件则负责定义Java类和JavaScript对象之间的对应关系。
- <?xml version="1.0" encoding="GBK"?>
- <web-app xmlns="http://java.sun.com/xml/ns/javaee"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
- http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" version="2.5">
-
- <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>/leedwr/*</url-pattern>
- </servlet-mapping>
- </web-app>
2.添加dwr.xml文件
1) 除此之外,还必须增加一个dwr.xml,该文件负责定义Java类和JavaScript对象之间对应关系。
- <?xml version="1.0" encoding="GBK"?>
-
- <!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 3.0//EN"
- "http://getahead.org/dwr/dwr30.dtd">
-
- <dwr>
- <allow>
- <!-- 使用new关键资创建一个Java实例
- 指定创建的JavaScript对象名为hello-->
- <create creator="new" javascript="hello">
-
- <param name="class" value="com.owen.dwr.HelloDwr"/>
- </create>
-
- <convert converter="bean" match="com.owen.dwr.domain.Person"/>
-
- <convert converter="object" match="com.owen.dwr.domain.Cat">
-
- <param name="force" value="true"/>
- </convert>
- </allow>
- <signatures>
- <![CDATA[
- import java.util.List;
- import com.owen.dwr.HelloDwr;
- import com.owen.dwr.domain.Person;
- HelloDwr.sendListNoGeneric(List<Person>);
- ]]>
- </signatures>
- </dwr>
2) dwr.xml文件说明
a) 在上面的配置文件,最重要的元素就是<allow…/>元素,如果一个dwr.xml文件没有定义<allow…/>元素,或者<allow…/>元素为空,则DWR将什么都干不了。<allow…/>元素里常用的元素是<create…/>和<conert…/>,其中<create…/>用于定义如何将一个Java类转换成一个JavaScript对象,而<convert…/>定义如何完成Java对象和JavaScript对象之间的转换。
b) DWR使用反射来确定Java实例和JavaScript对象之间的转换。在时候,参数类型信息并不十分明确,或者参数是一个集合对象,而且没有使用泛型来限制集合元素的类型,这就需要在dwr.xml文件的<signatures…/>元素中明确指定这些类型。
3.创建对应的类
在dwr.xml的文件中,我们添加了几个类,所以这个时候,我们需要提供这些类。
1) Cat.java
-
-
-
-
-
- public class Cat
- {
-
- private String name;
-
- public Cat(String name)
- {
- this.name = name;
- }
- }
2) Person.java
- package com.owen.dwr.domain;
-
-
-
-
-
-
- public class Person
- {
-
- private String name;
-
- public Person() {}
-
- public Person(String name)
- {
- this.name = name;
- }
-
-
- public void setName(String name)
- {
- this.name = name;
- }
- public String getName()
- {
- return this.name;
- }
- }
3) HelloDwr.java
- package com.owen.dwr;
-
- import java.util.*;
-
- import com.owen.dwr.domain.*;
-
-
-
-
-
-
- public class HelloDwr
- {
-
- public String hello(String name)
- {
- return name + ",您好!您已经开始了DWR的学习之旅,祝您学得开心...";
- }
-
- public String sendObj(Person p )
- {
- return p.getName() + ",您好!您已经学会了使用JavaBean参数...";
- }
-
- public Person getBean (String name)
- {
- return new Person(name);
- }
-
- public Cat getObject(String name)
- {
- return new Cat("服务器端" + name);
- }
-
- public List<Person> getPersonList()
- {
- List<Person> result = new ArrayList<Person>();
- result.add(new Person("集合aaaa"));
- result.add(new Person("集合bbbb"));
- result.add(new Person("集合cccc"));
- return result;
- }
-
- public Person[] getPersonArray()
- {
- Person[] result = new Person[3];
- result[0] = new Person("数组aaaa");
- result[1] = new Person("数组bbbb");
- result[2] = new Person("数组cccc");
- return result;
- }
-
- public Map<String, Person> getPersonMap()
- {
-
- Map<String, Person> result = new HashMap<String, Person>();
-
- result.put("first" , new Person("Map aaaa"));
- result.put("second" , new Person("Map bbb"));
- result.put("third" , new Person("Map cccc"));
-
- return result;
- }
-
- public String sendList(List<Person> pl)
- {
- String result = "";
- for (Person p : pl)
- {
- result += p.getName() + "<br />";
- }
- return result;
- }
-
- public String sendListNoGeneric(List pl)
- {
- String result = "";
- for (Object p : pl)
- {
- result += ((Person)p).getName() + "<br />";
- }
- return result;
- }
-
-
- public String sendMap(Map<String , Person> pmap)
- {
- String result = "";
- for (String key : pmap.keySet())
- {
- result += "键" + key + " 其值为:" +
- pmap.get(key).getName() + "<br />";
- }
- return result;
- }
- }
4.创建JS文件
创建个js文件名字叫hellodwr.js,这个文件可以直接调用java类中的方法。像hello.hello(name, cb)调用就是直接调用。
-
- function sendMessage()
- {
-
- var name = document.getElementById("name").value;
-
- hello.hello(name , cb)
- }
- function cb(data)
- {
- document.getElementById("show").innerHTML = data;
- }
-
- function sendObject()
- {
- var nameValue = document.getElementById("name").value;
-
- hello.sendObj({name:nameValue} , cb);
- }
-
-
- function getBean()
- {
- var name = document.getElementById("name").value;
-
- hello.getBean(name , beanCb)
- }
- function beanCb(data)
- {
-
- document.getElementById("show").innerHTML =
- data.name + ",您好,您已经学会了使用JavaBean返回值";
- }
-
- function getObject()
- {
- var name = document.getElementById("name").value;
-
- hello.getObject(name , objCb)
- }
- function objCb(data)
- {
-
- document.getElementById("show").innerHTML =
- data.name + ",是从服务器返回的猫的名字";
- }
-
- function getBeanList()
- {
-
- hello.getPersonList(listCb);
- }
-
-
- function listCb(data)
- {
- var result='';
-
- for (var i = 0 ; i < data.length ; i ++)
- {
- result += data[i].name + "<br />";
- }
- document.getElementById("show").innerHTML = result;
- }
-
- function getBeanArray()
- {
- hello.getPersonArray(arrayCb);
- }
- function arrayCb(data)
- {
- var result = "";
-
-
- for (var i = 0 ; i < data.length ; i ++)
- {
-
- result += data[i].name + "<br />";
- }
- document.getElementById("show").innerHTML = result;
- }
-
- function getBeanMap()
- {
- hello.getPersonMap(mapCb);
- }
-
-
- function mapCb(data)
- {
- var result='';
- for (var key in data)
- {
- result += "键为" + key + ",其值为:" + data[key].name + "<br />";
- }
- document.getElementById("show").innerHTML = result;
- }
-
-
- function sendBeanList()
- {
-
- var args = [
- {name:"客户端aaa"},
- {name:"客户端bbb"},
- {name:"客户端ccc"}
- ];
-
- hello.sendList(args , sendListCb);
- }
- function sendListCb(data)
- {
- document.getElementById("show").innerHTML = data;
- }
-
- function sendBeanListNoGeneric()
- {
-
- var args = [
- {name:"客户端aaa"},
- {name:"客户端bbb"},
- {name:"客户端ccc"}
- ];
-
- hello.sendListNoGeneric(args , sendListCb);
- }
-
- function sendBeanMap()
- {
-
- var args = {
- first:{name:"客户端aaa"},
- second:{name:"客户端bbb"},
- third:{name:"客户端ccc"}
- };
-
- hello.sendMap(args , sendMapCb);
- }
- function sendMapCb(data)
- {
- document.getElementById("show").innerHTML = data;
- }
5.创建前端html的文件
html的文件就是要调用hellodwr.js中的方法。
- <!DOCTYPE html>
- <html>
- <head>
- <meta name="author" content="OwenWilliam" />
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
- <title> DWR入门 </title>
-
- <script type='text/javascript' src='leedwr/engine.js'></script>
-
- <script type='text/javascript' src='hellodwr.js'></script>
-
- <script type='text/javascript' src='leedwr/interface/hello.js'>
- </script>
- </head>
- <body>
- <h3>DWR入门</h3>
- 请输入您的名字<input id="name" name="name" type="text"/><br />
- <input type="button" value="发送简单请求" onclick="sendMessage();"/>
- <input type="button" value="发送对象参数" onclick="sendObject();"/>
- <input type="button" value="返回JavaBean" onclick="getBean();"/><br />
- <input type="button" value="返回Object" onclick="getObject();"/>
- <input type="button" value="返回Bean集合" onclick="getBeanList();"/>
- <input type="button" value="返回Bean数组" onclick="getBeanArray();"/><br />
- <input type="button" value="返回Bean Map" onclick="getBeanMap();"/>
- <input type="button" value="发送Bean集合" onclick="sendBeanList();"/>
- <input type="button" value="发送不带泛型限制的Bean集合"
- onclick="sendBeanListNoGeneric();"/><br />
- <input type="button" value="发送Bean Map" onclick="sendBeanMap();"/>
- <hr />
- 下面是服务器的回应:<br />
- <div id= "show"></div>
- </body>
- </html>
--------------------------------------------------end----------------------------------------------------------------------------
亲测实例截图:
web.xml:
dwr.xml:
html页面:
js,在页面上直接调用后台方法。
前台页面显示:
debug状态:
目录结构:
ok!就到这里。
感谢网友 http://blog.csdn.net/owen_william/article/details/51346436
所有评论(0)