交易系统中有用到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.youkuaiyun.com/owen_william/article/details/51346436