`
冽豹之姿
  • 浏览: 41605 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

DWR学习文档(转)

    博客分类:
  • java
阅读更多
DWR是作为远程调用的ajax框架,将服务端的java类,方法和浏览器的javascript的类,方法对应起来。现在官方最新的版本是DWR2.0,可以在http://getahead.ltd.uk/dwr/download下载到。
我们真对DWR2.0做一些例子讲解一下它的特性:
Hello World:
新建一个web项目DWRStudy,在项目中构建路径中加入dwr.jar,
新建类Hello如下:


代码
package org.li.dwr;  

package org.li.dwr;  

import java.util.Date;  

public class Hello  
{  
    public String getHelloWorld()  
    {  
        return "现在的时间为:"+new Date();  
    }  
}


在WEB-INF目录下新建dwr.xml文件:

代码
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 2.0//EN" "http://www.getahead.ltd.uk/dwr/dwr20.dtd">
<dwr>
    <allow>
    <!-- javascript的对象是jshello,create="new"是DWR自己创建类 -->
        <create javascript="jshello" creator="new" scope="application">
            <param name="class" value="org.li.dwr.Hello"></param>
        </create>
    </allow>
</dwr>


在WebRoot目录里新建hello.js

代码
function load()//载入的时候调用  
{  
    var jbutton = document.getElementById("jbutton");  
    jbutton.onclick=function(event)//注册按钮点击事件  
    {  
        jbClick();  
    };  
}  
function jbClick()//按钮点击事件  
{  
    jshello.getHelloWorld(callback);//没有参数传递,只传递回调函数就行  
}  
function callback(msg)//回调函数  
{  
    DWRUtil.setValue('jdiv',msg);  
}


在WebRoot目录里新建HelloWorld.html

代码
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
    <title>HelloWorld.html</title>
    <meta http-equiv="content-type" content="text/html; charset=UTF-8">
    <script type='text/javascript' src='dwr/interface/jshello.js'></script>
    <script type='text/javascript' src='dwr/engine.js'></script>
    <script type='text/javascript' src='dwr/util.js'></script>
    <script type="text/javascript" src="hello.js"></script>

</head>
    
<body>
    <input id="jbutton" type="button" value="得到Hello World"/>
    <div id="jdiv"></div>
    <script>load()</script>
</body>
</html>


在web.xml中加入一个dwr的servlet:

代码
<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>


在运行一下服务器在浏览器里输入http://localhost:8080/DWRStudy/HelloWorld.html,然后点一下按钮下面就会显示服务端的系统时间了,而浏览器页面并没有被刷新。
下面解释一下:
1. 新建的Hello类中有一个getHelloWorld方法这个方法就是作为远程调用的服务端方法,这个Hello类也就是远程调用的类。方法的返回值为服务端当前的时间
2. dwr.xml是DWR用来配置服务端类和浏览器端javascript类之间的映射。可以下载dtd看一下,在<allow></allow>里类配置映射类如:<create javascript="jshello" creator="new" scope="application">
<param name="class" value="org.li.dwr.Hello"></param>
</create>
javascript="jshello"是在浏览器端的javascript的映射的类名,(不要用javascript里的关键字)creator="new"是表示这个类是dwr自己创建的,如果creator="new"那么就必须有下面的<param name=”class” value=”类的全路径”></param>,creator还可为spring(与spring集成的时候),script(与apache的一个框架BSF集成的时候用),后来又加入了struts,jsf,ejb3.现在是个HelloWorld让大家体验一下,具体后面会细讲。最后的scope=”application”是说这个pojo类的范围,和jsp是一样的。
3. 创建hello.js和HelloWorld.html都是看自己是怎么发挥了,注意的是在HelloWorld.html中导入js文件的时候注意顺序和路径命名规律,自己发挥的这个hello.js一定放在后面,因为要调用其它js文件中的函数。由于在HelloWorld.html里写入了<script>load()</script>所以在html加载的时候会调用hello.js里的load方法(注意这几个js文件里的函数最好不要重名)在load里面做的事情就是注册一下id为jbutton的按钮的点击事件。当我们点击id为jbutton的按钮的时候就开始用与服务器端的类相对应的javascript类了(jshello),直接调用jshello类的getHelloWorld方法,可以向函数传递参数,不过要在最后加一个回调函数。而我们的服务端的类没有参数就直接传回调函数了。在回调函数的形参msg是服务端Hello类中getHelloWorld方法返回值。在回调函数里面调用了DWR的工具类DWRUtil类的setValue方法设置id为jdiv的值。另外我们把doucment.getElementById(“jbutton”);换与$(“jbutton”)也可以得到同样的效果,这就有点像prototype了。
4. 在web.xml里加入DWRServlet的配置一是为了远程调用,二是自动生成了<script type='text/javascript' src='dwr/interface/jshello.js'></script>
<script type='text/javascript' src='dwr/engine.js'></script>
<script type='text/javascript' src='dwr/util.js'></script>文件。
上个HelloWorld例子只是返回了一个字符串,当然我们显示字符串很容易,可是如果返回一个对象怎么办呢?,DWR为我们将java类和javascript的DOM对象,不过这得需要我们在dwr.xml里配置。
再看一个综合的例子:
新建类User

代码
package org.li.dwr;  

import java.io.FileInputStream;  
import java.io.FileNotFoundException;  
import java.io.IOException;  
import java.util.ArrayList;  
import java.util.List;  
import java.util.Properties;  

public class User  
{  
    private String welcome;  
    private String username;  
    private String address;  
    private List<Book> books;  
    private int age;  
    public String getAddress()  
    {  
        return address;  
    }  
    public void setAddress(String address)  
    {  
        this.address = address;  
    }  
    public int getAge()  
    {  
        return age;  
    }  
    public void setAge(int age)  
    {  
        this.age = age;  
    }  
    public String getUsername()  
    {  
        return username;  
    }  
    public void setUsername(String username)  
    {  
        this.username = username;  
    }  
    public String getWelcome()  
    {  
        return welcome;  
    }  
    public void setWelcome(String welcome)  
    {  
        this.welcome = welcome;  
    }  
    public List<Book> getBooks()  
    {  
        return books;  
    }  
    public void setBooks(List<Book> books)  
    {  
        this.books = books;  
    }  
    public List<Book> getBook()  
    {  
        this.books = new ArrayList<Book>();  
        Book javaBook = new Book();  
        Book vcBook = new Book();  
        javaBook.setAuthor("孙鑫");  
        vcBook.setAuthor("孙鑫");  
        javaBook.setName("java Web开发详解");  
        vcBook.setName("vc++深入详解");  
        this.books.add(javaBook);  
        this.books.add(vcBook);  
        return this.books;  
    }  
    public User getUser(String welcome)  
    {  
        this.welcome=welcome;  
        try
        {  
            FileInputStream fis = new FileInputStream("D:\\workspace\\DWRStudy\\src\\user.properties");  
            Properties pp = new Properties();  
            pp.load(fis);  
            this.username=pp.getProperty("username");  
            this.age=Integer.valueOf(pp.getProperty("age"));  
            this.address=pp.getProperty("address");  
            fis.close();  
        }  
        catch (FileNotFoundException e)  
        {  
            // TODO Auto-generated catch block  
            e.printStackTrace();  
        }  
        catch (IOException e)  
        {  
            // TODO Auto-generated catch block  
            e.printStackTrace();  
        }  
        return this;  
    }  



新建Book类:

代码
package org.li.dwr;  

public class Book  
{  
    private String name;  
    private String author;  
    public String getAuthor()  
    {  
        return author;  
    }  
    public void setAuthor(String author)  
    {  
        this.author = author;  
    }  
    public String getName()  
    {  
        return name;  
    }  
    public void setName(String name)  
    {  
        this.name = name;  
    }  
}


新建DWRLog类

代码
package org.li.dwr.log;  

import java.lang.reflect.Method;  

import org.directwebremoting.AjaxFilterChain;  

public class DWRLog implements org.directwebremoting.AjaxFilter  
{  

    public Object doFilter(Object obj, Method method, Object[] params, AjaxFilterChain chain) throws Exception  
    {  
        System.out.println("过滤器Log输出:..对象:"+obj.getClass().getName()+"方法:"+method.getName());  
        return chain.doFilter(obj, method,params);  
    }  
      
}


新建D:\\workspace\\DWRStudy\\src\\user.properties
username=javafish
age=21
address=北京市海淀区
然后在dwr.xml里加入

代码
<create javascript="jsuser" creator="new">
            <param name="class" value="org.li.dwr.User"></param>
            <!-- 过滤允许调用的方法 -->
            <include method="getUser"/>
            <include method="getBook"/>
            <!-- 配置自己的过滤器 -->
            <filter class="org.li.dwr.log.DWRLog"></filter>
        </create>
        <!-- 需要转换的类 -->
        <convert match="org.li.dwr.User" converter="bean"></convert>
        <convert match="org.li.dwr.Book" converter="bean"></convert>


新建UserInfo.html

代码
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
    <title>UserInfo.html</title>
    <meta http-equiv="content-type" content="text/html; charset=UTF-8">
    <script type='text/javascript' src='dwr/interface/jsuser.js'></script>
    <script type='text/javascript' src='dwr/engine.js'></script>
    <script type='text/javascript' src='dwr/util.js'></script>
    <script type="text/javascript" src="userInfo.js"></script>

</head>
    
<body>
    请输入你的名字:  
    <input id="name" type="text"/>
    <input id="jbutton" type="button" value="得到javafish的信息"/>
    <input id="sbutton" type="button" value="得到javafish的书"/>
    <div id="result"></div>
    <script>load()</script>
</body>
</html>


新建userInfo.js

代码
function load()  
{  
    var jbutton = $("jbutton");  
    jbutton.onclick=function(event)  
    {  
        bOnClick();  
    };  
    var sbutton = $("sbutton");  
    sbutton.onclick=function(event)  
    {  
        sOnClick();  
    };  
}  
function bOnClick()  
{  
    jsuser.getUser($("name").value,callback);  
}  
function callback(msg)  
{  
    var user = msg;  
    DWRUtil.setValue('result',"欢迎你!"+user.welcome+"   姓名:"+user.username+",年龄:"+user.age+",住址:"+user.address+user.books[0].author);  
}  

function sOnClick()  
{  
    jsuser.getBook(callbackBooks);  
}  
function callbackBooks(msg)  
{  
    alert(msg);  
    DWRUtil.setValue('result',msg);  
}


运行服务器输入http://localhost:8080/DWRStudy/UserInfo.html,可看到运行结果
这个例子需要解释的就是dwr.xml了
在这里用到了两个java类,User、Book,方法呢就是User.getUser和User.getBook,而Book类呢由于我们没有在javascript中调用,所以就不用配置Book的create了。
大家可能会奇怪为什么会多出来两个<convert match="org.li.dwr.User" converter="bean"></convert>
<convert match="org.li.dwr.Book" converter="bean"></convert>
呢,是因为在调用getBook和getUser的时候会返回给javascript有关User和Book的对象或数据,这里的用<convert match=”类” converter=”bean”/>做一下转换,否则javascript将不会得到有效的数据。
下面讨论一下DWR的安全性,由于我们将javaBean整体都对外暴露了,所以说会有非常多的安全问题,真对这些DWR也作了一些的措施就是上面例子中dwr.xml的配置:
<include method="getUser"/>
<include method="getBook"/>
<filter class="org.li.dwr.log.DWRLog"></filter>
这样配置的话就只暴露了User类的两个方法getUser,getBook。就相对安全多了,相反还有<exclude>的配置它们是类似的。对于安全我们也可以用DWR的过滤器来实现,这里我用过滤器实现的是一个日志记录。过滤器类只需要实现AjaxFilter接口就可以了,不过注意的是这个过滤器不是HttpServelt的过滤器而是DWR自己内部实现的(有兴趣可以查看一下源代码)。
真对DWR的安全性上来说,官方也不敢保证,官方只是说自己可以看一下源代码因地施宜。
不过DWR可以和acegi集成,让acegi来管理安全问题。由于acegi我还没有完全搞定关于DWR和acegi的集成,先放一放日后补充。
下面对DWR.xml的配置具体补充一下:
首先是<init></init>里面有<converter>和<create>是配置在初始化的时候需要创建和转化的类。
然后是<allow></allow>里面有<converter>和<create>这个地方就是正式的配置了,creator里有param,filter,include,exclude,auth,除了auth我们都接触过了,而auth是集成J2EE的安全认证用的,这个可能和acegi的集成有关吧(?)。<converter>呢,它的converter有很多
? Array Converter
? Bean and Object Converters
? Collection Converter
? Enum Converter
? DOM Objects
这些都是转换的时候配置的
还有就是<signatures></signatures>的配置了,申明一些不java用反射不可得到的参数类型。
我在上面例子上用的getBook来本来想用signatures实现List<Book>的转换可是没有成功(不用配置就可以)
主要是真对jdk1.4以下的,我本机用的是jdk6,所以屡试不爽最后在官方DWR2的特性中看到如果你用的是DWR2和JDK5以上的话就不用配置了DWR会自动转换。
下面讲一下DWR与Spring的集成:
还是上面那个例子用Spring搞定大部分和上面一样
新建类User(包换了)

代码
package org.li.dwr.spring;  

import java.util.List;  

import org.li.dwr.Book;  

public class User  
{  
    private String welcome;  
    private String username;  
    private String address;  
    private List<Book> books;  
    private int age;  
    public String getAddress()  
    {  
        return address;  
    }  
    public void setAddress(String address)  
    {  
        this.address = address;  
    }  
    public int getAge()  
    {  
        return age;  
    }  
    public void setAge(int age)  
    {  
        this.age = age;  
    }  
    public String getUsername()  
    {  
        return username;  
    }  
    public void setUsername(String username)  
    {  
        this.username = username;  
    }  
    public String getWelcome()  
    {  
        return welcome;  
    }  
    public void setWelcome(String welcome)  
    {  
        this.welcome = welcome;  
    }  
    public List<Book> getBooks()  
    {  
        return books;  
    }  
    public void setBooks(List<Book> books)  
    {  
        this.books = books;  
    }  
    public User getUser(String welcome)  
    {  
        this.welcome=welcome;  
        return this;  
    }  
}

分享到:
评论

相关推荐

    DWR中文文档DWR

    DWR(Direct Web Remoting)是一种Java库,它允许JavaScript在客户端与服务器...通过深入学习这份DWR中文文档,开发者不仅可以掌握DWR的基本用法,还能了解到如何在实际项目中有效利用DWR提升Web应用的性能和用户体验。

    DWR中文文档v0.9PDF

    《DWR中文文档v0.9PDF》是一个关于Direct Web ...总的来说,通过深入学习《DWR中文文档v0.9PDF》,开发者可以掌握DWR的基本原理和高级特性,从而在Web应用开发中充分利用DWR的优势,构建更加动态和交互性强的网页应用。

    DWR中文文档.pdf

    ### DWR中文文档知识点概述 ...通过对DWR中文文档的学习,我们可以了解到如何配置DWR环境、如何使用JavaScript与服务器端交互,以及如何与其他流行框架整合。这对于提高Web应用程序的开发效率和质量具有重要意义。

    DWR学习资料

    DWR学习资料 :DWR 3.0 上传文件.txt DWR3.0反向Ajax示例.txt DWR3.0学习笔记.txt DWR3.0学习网址.txt dwr分页.doc DWR分页代码.doc DWR中文文档.doc DWR中文文档.pdf dwr做comet的完整实现.doc Spring整合DWR comet ...

    DWR中文帮助文档(最好的DWR中文帮助文档)

    总的来说,这份“DWR中文帮助文档”是学习和使用DWR的关键资源,它能够帮助开发者高效地理解和应用DWR,实现JavaScript与Java后端的无缝交互,创建高性能的Web应用。通过阅读和实践文档中的内容,开发者可以深入理解...

    DWR中文文档、学习文档

    4. "DWRdoc.zip":可能包含DWR的官方文档,提供详细的技术参考。 通过以上内容,我们可以看出DWR是一个强大且灵活的工具,它简化了Ajax开发,提高了Web应用的交互性。掌握DWR,可以提升开发效率,创造出更加动态和...

    DWR中文文档

    DWR(Direct Web Remoting)是一个开源的Java...通过学习这份DWR中文文档,你将能够理解和掌握DWR的工作原理,有效地在Web应用中使用DWR进行AJAX开发,提升用户体验,并了解如何在实际项目中安全、高效地运用这一技术。

    DWR的学习资料,DWR学习必备

    DWR中文文档.pdf:这是DWR的官方中文文档,详细解释了DWR的各个方面,包括安装、配置、API使用、安全性和最佳实践。对于初学者来说,这是一个宝贵的资源,可以帮助理解并熟练掌握DWR。 DWR开发培训.ppt、DWR.ppt:...

    dwr3api+DWR文档.pdf

    Direct Web Remoting (DWR) 是一个开源Java库,它允许Web应用程序在浏览器和服务器之间进行安全、简单、异步的通信。DWR的核心功能是将...通过学习和掌握DWR,你可以更高效地开发出具有实时更新功能的网页应用。

    dwr中文文档pdf格式

    这份中文文档详细介绍了DWR的相关概念和技术,对于学习和使用DWR的开发者来说是一份非常宝贵的资源。 **1. DWR基本概念** DWR的核心是反向Ajax(Reverse AJAX),即服务器可以主动向客户端发送数据,而不仅仅局限于...

    DWR学习文档易懂 好东西

    **DWR(Direct Web Remoting)技术详解** DWR,全称为Direct Web Remoting,是一种在Web应用程序中实现...结合提供的"DWR中文文档.pdf",你可以深入研究DWR的配置、使用方法以及案例实践,进一步提升你的Web开发技能。

    DWR中文官方文档-打包下载

    DWR(Direct Web ...通过“DWR中文官方文档”,开发者可以学习到如何在实际项目中有效利用DWR,提高Web应用的交互性和响应速度。文档涵盖了安装、配置、使用示例、API参考等多个方面,是学习和使用DWR的宝贵资源。

    DWR3.0 jar包API文档

    - **性能优化**:学习如何利用DWR的缓存机制和其他优化策略,提高应用的性能。 总的来说,DWR3.0是一个强大的工具,它简化了JavaScript与Java的交互,使开发者能够构建出更加动态和响应式的Web应用。通过深入理解和...

    DWR中文文档 ,非常详细

    DWR(Direct Web Remoting)是一种...通过学习这份详尽的DWR中文文档,开发者可以深入了解DWR的工作原理,熟练运用其功能,构建高效、用户体验优秀的Web应用。无论是初学者还是经验丰富的开发者,都能从中受益匪浅。

    DWR文档,很全的文档,很好用

    Direct Web Remoting (DWR) 是...通过学习和使用DWR,开发者能够快速构建动态、交互性强的Web应用,而无需深入研究底层的AJAX和HTTP通信细节。同时,DWR的广泛兼容性和丰富的特性使其成为开发富互联网应用的理想选择。

    DWR中文文档和jar

    这对于我们理解和使用DWR非常有帮助,特别是对于中文使用者,中文文档能够降低学习和理解的难度,提高开发效率。 DWR中文文档可能涵盖了以下关键概念和特性: 1. **介绍**:DWR的基本理念、工作原理以及如何集成到...

    DWR中文文档 dwr入门 dwr.jar

    Direct Web Remoting (DWR) ...学习DWR能够提升你构建实时Web应用的能力,理解其工作原理和使用技巧,可以帮助你更高效地开发动态、交互性强的网页应用。通过深入阅读提供的文档和示例,你将更好地掌握这一强大的工具。

    个人学习收集 DWR中文文档

    这个“个人学习收集 DWR中文文档”压缩包包含了一份详细的DWR中文教程,对于想要深入理解和使用DWR技术的开发者来说是宝贵的资源。 DWR的核心功能在于实现AJAX(Asynchronous JavaScript and XML)的简化,使得动态...

Global site tag (gtag.js) - Google Analytics