DWR做为一个优秀的服务器端ajax框架。特色是很是突出的。3.0版又增长了一些新的功能。值得确定!
在应用中使用dwr实际上是很是简单的。下面以一个极简单的步骤来展示它的简单性和实用性:
1、给应用增长对dwr的支持
一、将dwr.jar包放入应用的lib包下
二、配置web.xml
- <!-- 加入dwr的支持 -->
- <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>/dwr/*</url-pattern>
- </servlet-mapping>
三、配置dwr.xml
在web.xml同目录下配置一个dwr.xml文件。它的做用有点相似spring的applicationContext.xml。主要是将全部须要在页面由脚本程序调用的java类配置进去。如:
Java代码
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 3.0//EN" "http://getahead.org/dwr/dwr30.dtd">
-
- <dwr>
-
- <allow>
- <!--dwr3提供的一个日志审核过滤器-->
- <filter class="org.directwebremoting.filter.AuditLogAjaxFilter"/>
-
- <!--这是我配置的一个演示类,javascript="Demo" 表示,我能够在页面中用Demo这个名称指向DwrDemo这个java类,类中的方法能够在前台调用-->
- <create creator="new" javascript="Demo">
- <param name="class" value="cn.ibeans.demo.dwr.DwrDemo"/>
- </create>
-
-
- <!-- this is a bad idea for live, but can be useful in testing -->
- <convert converter="exception" match="java.lang.Exception"/>
- <convert converter="bean" match="java.lang.StackTraceElement"/>
-
- </allow>
-
- </dwr>
2、添加java类(被配置到dwr.xml中)
DwrDemo.java:
Java代码
- package cn.ibeans.demo.dwr;
-
- public class DwrDemo {
- public String getHello(String name){
- return name+" 你好!";
- }
- }
3、前台页面中使用dwr
dwr.jsp:
Java代码
- <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
- <%@ taglib prefix="s" uri="/struts-tags"%>
-
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
- <html>
- <head>
- <title>Dwr Demo</title>
- <script type='text/javascript' src='${pageContext.request.contextPath}/dwr/engine.js'> </script>
- <script type='text/javascript' src='${pageContext.request.contextPath}/dwr/util.js'> </script>
- <script type='text/javascript' src='${pageContext.request.contextPath}/dwr/interface/Demo.js'> </script>
- <script type="text/javascript">
- //此函数中能够调用java类的方法,除了java方法自己的参数外,还要将回调函数名做为参数传给java方法
- function sayHello(name){
- Demo.getHello(name,dwrHandler);
- }
-
- //这是dwr的一个回调函数,data参数即java方法getHello(String name)的返回值
- function dwrHandler(data){
- alert(data);
- }
- </script>
- </head>
-
- <body>
- <h1>Hello World!</h1>
- <script type="text/javascript">
- sayHello("张三");
- </script>
- </body>
- </html>
注:jsp文件中必须引入几个js,它们都是隐含存在的,不用考虑它们在哪儿。其中engine.js和util.js是固定的。另外的一个js的名称就是dwr.xml中配置的类名。这些js的路径基本是:app_root/dwr/....模式的,必定要写对。