一、配置DWR使用注解功能
如果让dwr使用注解功能需要在web.xml进行如下配置:
-
<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>
-
<!-- 将设定注解的域对象和业务实现类放在下面列表中,中间使用逗号间隔 -->
-
<init-param>
-
<param-name>classes</param-name>
-
<param-value>
- com.dwr.test.Book,
- com.dwr.test.Bank,
- com.dwr.test.dao.BookDao
-
</param-value>
-
</init-param>
-
</servlet>
-
<servlet-mapping>
-
<servlet-name>dwr-invoker</servlet-name>
-
<url-pattern>/dwr/*</url-pattern>
-
</servlet-mapping>
这样设置之后就可以在dwr中使用注解了,非常的方便。
二、DWR提供的注解类型
经常用到的注解主要有:@RemoteProxy、@RemoteMethod、@DataTransferObject和@RemoteProperty。
1. @RemoteProxy和@RemoteMethod
@RemoteMethod对应于原来dwr.xml文件中的create标签,用于创建DWR所提供的远程方法;而@RemoteMethod对应于create标签中的 <include method=”"/>,用来指定所要暴露的方法名称。我们举例来说明:
-
@RemoteProxy(name="bankFunctions")
-
public class Bank {
-
-
@RemoteMethod
-
public void buy() {
-
// ...
-
}
- }
从上面可以看出,@RemoteProxy表示这个类将用于远程方法,而使用@RemoteMethod指定所要暴露的方法,没有使用@RemoteMethod的方法将不会显示在客户端。
上面的注释使用dwr.xml表示如下:
-
<!DOCTYPE dwr PUBLIC
-
"-//GetAhead Limited//DTD Direct Web Remoting 2.0//EN"
-
"http://getahead.ltd.uk/dwr/dwr20.dtd">
-
<dwr>
-
<allow>
-
<create creator="new" javascript="bankFunctions">
-
<param name="class" value=" com.dwr.test.Bank" />
-
<include method="buy" />
-
</create>
-
</allow>
-
</dwr>
如果使用Spring中的DAO或逻辑层则需要进行如下的设置:
- // BookDao
-
@RemoteProxy(creator = SpringCreator.class,
-
creatorParams = @Param(name = "beanName", value = "bookDao"),
-
name="bookFunctions")
-
public class BookDao {
-
-
@RemoteMethod
-
public void addBook(Book book) {
-
// ...
-
}
- }
通过指定@RemoteProxy中的creator类型为SpringCreator,然后在creatorParams指定对应的beanName名称。对应的dwr.xml文件如下:
-
<!DOCTYPE dwr PUBLIC
-
"-//GetAhead Limited//DTD Direct Web Remoting 2.0//EN"
-
"http://getahead.ltd.uk/dwr/dwr20.dtd">
-
<dwr>
-
<allow>
-
<create creator="spring" javascript="bookFunctions">
-
<param name="beanName" value="bookDao" />
-
<include method="addBook" />
-
</create>
-
</allow>
-
</dwr>
2. @DataTransferObject和@RemoteProperty
@DataTransferObject对应于原来dwr.xml文件中的convert标签,用于转换Java对象;@RemoteProperty则对应于convert标签中的 <param name=”include” value=”" />。
举例说明一下:
-
@DataTransferObject
-
public class Book {
-
@RemoteProperty
-
private int id;
-
-
@RemoteProperty
-
private String name;
-
-
public Book() {
-
}
-
-
public int getId() {
-
return id;
-
}
-
-
public void setId(int id) {
-
this.id = id;
-
}
-
-
public String getName() {
-
return name;
-
}
-
-
public void setName(String name) {
-
this.name = name;
-
}
- }
@RemoteProperty可以放在JavaBean中的私有变量上面,也可以放在getXXX方法上面。另外如果想将JavaBean中所有的属性都暴露出来的话,不需要在任何属性上面添加@RemoteProperty注释就可以了。
上面的注释对应的dwr.xml文件如下:
-
<!DOCTYPE dwr PUBLIC
-
"-//GetAhead Limited//DTD Direct Web Remoting 2.0//EN"
-
"http://getahead.ltd.uk/dwr/dwr20.dtd">
-
<dwr>
-
<allow>
-
<convert converter="bean"
-
match="com.javatang.domain.Book">
-
<param name="include" value="id, name" />
-
</convert>
-
<!-- 或者用下面的方式也可以
- <convert converter="bean" match="com.javatang.domain.Book" />
- -->
-
</allow>
-
</dwr>
关于具体每个注释使用的方法已经所包含的参数可以参考Java Doc。使用DWR2.0的注解极大的简化了原来dwr.xml的配置,非常的方便。
总结:
针对DWR对Javabean的注解分为两类:
Object和Class
针对Class的注解使用:
@RemoteProperty注解类为远程访问类,相等于create
@RemoteMethod 注解类为远程访问方法,相等于dwr.xml中白名单中注解的方法
注意默认的类中所有的方法为全部在黑名单中。不可作为远程访问对象的。
针对:Object使用@DataTransferObject 和@RemoteProperty注解接口
@DataTransferObject仅仅注解类对象
@RemoteProperty注解属性和方法的应用
使用远程访问类的
package com.dwr.test;
import org.directwebremoting.annotations.RemoteMethod;
import org.directwebremoting.annotations.RemoteProxy;
/**
* 注解此类为远程访问对象的应用
* @author Rabby
*
*/
@RemoteProxy(name = "DWRAnnotation")
public class DWRAnnotation {
/**
* 注解此方法为远程方法的
* @param username
* @return
*/
@RemoteMethod
public String hello(String username) {
return "Hello ," + username;
}
}
web.xml的配置信息:
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<servlet>
<servlet-name>dwr</servlet-name>
<servlet-class>
org.directwebremoting.servlet.DwrServlet
</servlet-class>
<!-- 用于测试dwr的模式 -->
<init-param>
<param-name>debug</param-name>
<param-value>true</param-value>
</init-param>
<!-- 针对注解类必须使用的远程访问对象的描述 -->
<init-param>
<param-name>classes</param-name>
<param-value>
com.dwr.test.DWRAnnotation
</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>dwr</servlet-name>
<url-pattern>/dwr/*</url-pattern>
</servlet-mapping>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>
相应的jsp页面用于测试注解的使用
<%@ page language="java" import="java.util.*" pageEncoding="ISO-8859-1"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme() + "://"
+ request.getServerName() + ":" + request.getServerPort()
+ path + "/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>My JSP 'index.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<script type='text/javascript'
src='/DWRAnnotation/dwr/interface/DWRAnnotation.js'></script>
<script type='text/javascript' src='/DWRAnnotation/dwr/engine.js'></script>
<script type='text/javascript' src='/DWRAnnotation/dwr/util.js'></script>
<script type="text/javascript">
function helloMessage()
{
var username=DWRUtil.getValue("username");
DWRAnnotation.hello(username,function(data)
{
DWRUtil.setValue("message",data);
});
}
</script>
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
</head>
<body>
UserName:
<input type="text" id="username" name="username" value="" />
<div id="message"></div>
<input type="button" onclick="helloMessage()" />
</body>
</html>
http://www.open-lib.com/
分享到:
相关推荐
springMvc + dwr 注解 实现消息推送 ,支持单个用户精确推送以及指定成员.群推送. 不需要任何配置修改,即可使用
Dwr例子 简单的例子 是一个小web 工程 谁看谁会 不要10分 也不要5分 只要3分啊亲 只要3分Dwr例子抱回家
DWR 初始,返回字符串&对象&列表 DWR 初始,返回字符串&对象&列表
NULL 博文链接:https://j4t.iteye.com/blog/1562162
DWR.xml配置文件说明.doc
该文件中包括了dwr框架和spring框架结合使用方法,使用注解方式。
Dwr3+Spring3 全注解 annotation 方式实现
dwr配置文件和注解两种方式的两个demo, dwr框架在项目中的使用, 一个sprig3+dwr3+jpa+struts2,基于注解的完整demo 一个sprig2+dwr2+hibernate3+struts1,基于配置文件的完整demo ...
配置整合DWR3.0和Spring2.5使用annotation注解
使用注解整合ext dwr spring hibernate
这是,以上两个版本的升级版,在原有的基础上,增加了 清空聊天记录,上线通知,用户id,及登录的所在地(ip),聊天信息可选择颜色, ps: 测试的时候记得将 info.txt(聊天信息保存文件) 绝对路径覆盖源码中,以前的路径,
dwr各种例子各种数据类型(包括基本数据类型,实体,List,List,Map,Map,Object>),导入即可用,有注释,方便理解,另附加详细讲解,一看便懂!
NULL 博文链接:https://medbricom.iteye.com/blog/1186774
S2SH整合dwr,通过DWR实现了web即时通讯的功能。整个项目源码全在这里,还有说明!不明白的请给我来信!
1.针对SpringMVC注解的配置,可起到入门的作用 2.Spring+JdbcTemplate事物管理 ...4.Spring实现DWR注解方式的应用配置 5.Spring配置拦截器 6.Spring通过拦截器实现防止重复提交实例 对学习,会起到非常好的效果
dwr3实现服务器根据用户id向前端用户精准推送的实例,直接解压可运行,实例内部注解清晰,初学者可也看懂。访问http://localhost:8080/dwr/登录,访问http://localhost:8080/dwr/MyJsp.jsp进行推送。 放到myeclipse...
整合spring3 + struts2 + mybatis3 + tiles + dwr3 这几个流行的框架。 spring3,struts2,dwr3都是用的注解,tiles与mybatis是采用的xml配置。
用DWR框架做的一个在页面显示 返回为List类型数据的小例子,里面有详细的注释,用MyEclipse做的,可以直接运行。
利用dwr 反转 ajax 做的一个广播,或者说是群聊的小工程, 加入了流技术,加密保存聊天信息至文本文档中,代码有详细注释,页面美观,简洁,........
struts2.2.1+spring 3.0.3+hibernate3.6+dwr3.0全注解整合包