一、DWR简介
DWR是一个开源的java包,可以使浏览器中的代码使用web服务器中java类的方法,就像这个方法就是在浏览器中一样。
DWR包括两个部分:一个运行在服务器端的Java Servlet,负责处理浏览器的请求并发送反馈给浏览器;另一个是运行在浏览器端的Java Script,负责发生请求并动态修改web页面。
DWR的原理就是基于java类动态产生javascript代码,AJAX使得服务器端java类的方法好像是在是在浏览器端执行的,这种类似传统RPC机制,就很象RMI,或SOAP。而且它的优势是在web上运行但不需要浏览器插件。
二、步骤:
1.下载dwr.jar,放在WEB-INF/lib 或其他合适地方
2.修改web.xml,增加:
<servlet></servlet>
<servlet></servlet>
- <servlet>
- <servlet-name>dwr-invokerservlet-name>
- <display-name>DWR Servletdisplay-name>
- <servlet-class>uk.ltd.getahead.dwr.DWRServletservlet-class> //如果是DWR 2.x,改成org.directwebremoting.servlet.DwrServlet
- <init-param>
- <param-name>debugparam-name>
- <param-value>trueparam-value>
- init-param>
- servlet>
- <servlet-mapping>
- <servlet-name>dwr-invokerservlet-name>
- <url-pattern>/dwr/*url-pattern>
- servlet-mapping>
3.创建dwr.xml
如:<servlet-name></servlet-name>
- "-//GetAhead Limited//DTD Direct Web Remoting 1.0//EN"
- "http://www.getahead.ltd.uk/dwr/dwr10.dtd">
- <dwr>
- <allow>
- <create creator="new" javascript="JDate"> //JS使用的类名
- <param name="class" value="java.util.Date"/> //实际java的类
- <create>
- <create creator="new" javascript="Demo" scope="page/request/session/application"> //可以设置对象保存的位置
- <param name="class" value="your.java.Bean"/>
- create>
- allow>
- dwr>
这个XML文件是定义DWR可以创建什么类并可以被JS远程调用。
注意不要使用保留字,注意不要让一个方法负担过重。
4.访问URL:
http://localhost:8080/[YOUR-WEBAPP]/dwr/
可以看到dwr.xml中定义的类,点击某个类,可以看到这个类有哪些方法可以调用。以及在js中需要include哪个js,还可以在这个页面上测试各个方法。
一般jsp页面中需要加入: <script type="text/javascript" src="<a href="http://envysiongdc.boldtech.com/dwr/engine.js">/dwr/engine.js</a>"></script> <script type="text/javascript" src="<a href="http://envysiongdc.boldtech.com/dwr/interface/DwrService.js">/dwr/interface/DwrService.js</a>"></script> <script type="text/javascript" src="<a href="http://envysiongdc.boldtech.com/dwr/util.js">/dwr/util.js</a>"></script>
- <script type='text javascript' src="/dwr/</span><span class="keyword">interface</span><span>/Demo.js"></script> //这个是用户自定义的dwr服务动态产生的js
- <script type='text javascript' src="/dwr/engine.js"></script> //这个是必须的
<script type='text javascript' src="/dwr/util.js"></script> //这是可选的
5.写服务端的JAVA类
如上面的例子即写一个your.java.Bean类
6.写客户端的js
7.一个简单的完整的代码例子
- public class Remote {
- public String getData(int index) { ... }
- }
- function handleGetData(str) {
- alert(str);
- }
- Remote.getData(42, handleGetData);