最近在用ext+spring框架写应用,经常涉及到前后台数据传递的问题。于是就学习了下dwr,在此将dwr和spring的整合做下整理并记录在此,以便以后回顾.
本人不喜欢过多的配置的烦琐,发现注解用起来工程比较干净,这里就不对配置文件实现的方式进行整理了。
第一步:在web.xml文件中配置dwr的servlet,修改web.xml的文件配置:
- <!-- dwr 配置 -->
- <servlet>
- <servlet-name>dwr</servlet-name>
- <servlet-class>org.directwebremoting.spring.DwrSpringServlet</servlet-class>
- <init-param>
- <param-name>debug</param-name>
- <param-value>true</param-value>
- </init-param>
- </servlet>
- <servlet-mapping>
- <servlet-name>dwr</servlet-name>
- <url-pattern>/dwr/*</url-pattern>
- </servlet-mapping>
<!-- dwr 配置 --> <servlet> <servlet-name>dwr</servlet-name> <servlet-class>org.directwebremoting.spring.DwrSpringServlet</servlet-class> <init-param> <param-name>debug</param-name> <param-value>true</param-value> </init-param> </servlet> <servlet-mapping> <servlet-name>dwr</servlet-name> <url-pattern>/dwr/*</url-pattern> </servlet-mapping>
第二步:配置dwr标签:
- <!-- 注意这里新增加的dwr tag, 为使其生效,文件头中要声明namespace -->
- <dwr:configuration />
- <!-- 扫描读取注解加载的类 -->
- <dwr:annotation-scan scanRemoteProxy="true" base-package="com.mb.dwrService" />
- <dwr:url-mapping />
- <!-- 部署项目时, 请把debug设为false -->
- <dwr:controller id="dwrController" debug="true" />
<!-- 注意这里新增加的dwr tag, 为使其生效,文件头中要声明namespace --> <dwr:configuration /> <!-- 扫描读取注解加载的类 --> <dwr:annotation-scan scanRemoteProxy="true" base-package="com.mb.dwrService" /> <dwr:url-mapping /> <!-- 部署项目时, 请把debug设为false --> <dwr:controller id="dwrController" debug="true" />
注:在配置文件中使用dwr的标签,必须声明namespace
第三步:编写服务端server:
- package com.mb.dwrService;
- import org.directwebremoting.annotations.RemoteMethod;
- import org.directwebremoting.annotations.RemoteProxy;
- <SPAN style="COLOR: #000000">@RemoteProxy(name="loginService")</SPAN>
- public class LoginSerivce {
- <SPAN style="COLOR: #000000">@RemoteMethod</SPAN>
- public String test(){
- return "进入!";
- }
- public String ptest(){
- return "PP";
- }
- }
package com.mb.dwrService;
import org.directwebremoting.annotations.RemoteMethod;
import org.directwebremoting.annotations.RemoteProxy;
@RemoteProxy(name="loginService")
public class LoginSerivce {
@RemoteMethod
public String test(){
return "进入!";
}
public String ptest(){
return "PP";
}
}
第四步:启动服务,访问测试url:
http://localhost:8080/[webapp]/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">
<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的配置,非常的方便。