dwr配置说明

Ajax,它使浏览器可以为用户提供更为自然的浏览体验,对于j2EE WEB开发人员来说,使用DWR框架可以很简单的使用Ajax技术. 
本文以一个DWR+SPRING的实例来说明DWR的使用 
1、将dwr.jar放到应用的/WEB-INF/lib目录下

2、配置web.xml,增加如下代码: 红色表示要添加的部分

web.xml:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="2.5" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee   http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
<servlet>
    <servlet-name>action</servlet-name>
    <servlet-class>org.apache.struts.action.ActionServlet</servlet-class>
    <init-param>
      <param-name>config</param-name>
      <param-value>/WEB-INF/struts-config.xml</param-value>
    </init-param>
    <init-param>
      <param-name>debug</param-name>
      <param-value>3</param-value>
    </init-param>
    <init-param>
      <param-name>detail</param-name>
      <param-value>3</param-value>
    </init-param>
    <load-on-startup>0</load-on-startup>
</servlet>
<filter>
    <description>This is the description of my J2EE component</description>
    <display-name>This is the display name of my J2EE component</display-name>
    <filter-name>GBKFilter</filter-name>
    <filter-class>com.jxc.commons.GBKFilter</filter-class>
</filter>
<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>
<servlet-mapping>
    <servlet-name>action</servlet-name>
    <url-pattern>*.do</url-pattern>
</servlet-mapping>
<filter-mapping>
    <filter-name>GBKFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>
<welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>

3、在WEB-INF下增中dwr.xml文件:

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" >
<!-- <!DOCTYPE dwr SYSTEM "dwr20.dtd" > -->
<dwr>
       <allow>

<!--creator属性的值可以是new,struts,spring......因为此处是整合spring来做的,所以设置成“spring”,javascript="personnelJS" 表示实例转换成javascript语言后以personnelJS命名 -->
            <create javascript="personnelJS" creator="spring">

<!-- param元素的name属性值可以是class,beanName等,此处用beanName,value得值是定义在applicationContext.xml中某个bean的id值。-->
              <param name="beanName" value="personnelAJAX"></param>

<!-- 该param指dwr查找spring配置文件的路径 -->
              <param name="location" value="applicationContext.xml" />

<!-- include指要经spring执行的类的那个方法转换到js文件中 -->
              <include method="getPersonnel"/>
            </create>

<!-- comvert属性指转换成js的类方法如果返回的是对象或者集合时,对象的类型是哪个实体 -->
            <convert match="com.jxc.config.entity.Personnel" converter="bean">

<!-- parame属性指将实体对象的那些字段生成js文件,而不用将实体的所有属性都生成js文件 -->
            <param name="include" value="id,userName,department,password,gongZi,sex,telephone,qq,email,address,idcard,quanXian"></param>
            </convert>
            <convert match="com.jxc.config.entity.Department" converter="bean">
            <param name="include" value="id,department"></param>
            </convert>
       </allow>
</dwr>

4、创建一个实体bean供DWR转换成js

package com.jxc.config.service;

import com.jxc.config.entity.Personnel;

public class PersonnelManager {
private IPersonnelService personneService = null;

public void setPersonneService(IPersonnelService personneService) {
   this.personneService = personneService;
}
public Personnel getPersonnel(int id){
   return personneService.getById(id);
  
}

}

5、在applicationContext.xml中配置第4步写的bean

<!-- ajax Bean -->
   
    <bean id="personnelAJAX" class="com.jxc.config.service.PersonnelManager">
     <property name="personneService" ref="personnelService"></property>
    </bean>

6、测试是否成功:

http://localhost:8080/项目名/dwr/index.html

7、在jsp页面中调用 
先导入以下文,每个文件的功能这里不再详述 
<script type='text/javascript'
    src='/jxcSoftware/dwr/interface/personnelJS.js'></script>
   <script type='text/javascript' src='/jxcSoftware/dwr/engine.js'></script>
   <script type='text/javascript' src='/jxcSoftware/dwr/util.js'></script>

var reply0 = function(personnel) {
   if (personnel != null) {
    var outHtml = "<table border='0' cellpadding='0' cellspacing='1' class='AllmiddleTable' id='AllmiddleTable'>";
    outHtml += "<tr><td class='leftTitle' style='background-color: #eef7fd' align='right' width='150px'>所属部门</td>";
    outHtml += "<td style='color: #1a438e;'>" + personnel.department.department + "</td></tr>";
    outHtml += "<tr><td class='leftTitle' style='background-color: #eef7fd' align='right' width='150px'>员工编号</td>";
    outHtml += "<td style='color: #1a438e;'>" + personnel.id + "</td></tr>";
      outHtml += "</table>";
    var oTable = document.getElementById("tPersonnelDetail");
    oTable.innerHTML = outHtml;
   }
}

function ShowPersonnel(personnelId) {
   personnelJS.getPersonnel(personnelId, reply0);
   ShowDiv('dvCus');
}

function CloseDiv(id) {
   var oDiv = document.getElementById(id);
   if (oDiv) {
    oDiv.style.display = "none";
   }
}
function ShowDiv(id) {
   var oDiv = document.getElementById(id);
   if (oDiv) {
    oDiv.style.display = "block";
   }
}

// 页面调用标签

<td ondblclick="ShowPersonnel('${personnel.id}');" style="cursor: pointer;">
          <bean:write name="personnel" property="id" />
</td>




 

 

 

<?xml version="1.0" encoding="UTF-8"?>    
<!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 2.0//EN" "http://getahead.org/dwr/dwr20.dtd">    
   
<dwr>    
  <allow>    
    <create creator="spring"   javascript="dwrpro">    
        <!-- 是指spring中的beanName,即ID的名字 -->    
        <param name="beanName" value="dwr"/>    
        <!-- 本对象在spring哪个配置文件中 -->    
        <param name="location" value="applicationContext-common.xml"/>    
                  <!-- 要暴露出来方法-->    
        <include method="checkUserName"/>    
        <include method="searchChildArea"/>    
        <include method="searchChildTrade"/>    
            
    </create>    
    <!-- 此配置用于将bean转换到客户端 -->    
    <convert converter="bean" match="com.umn.pojo.User">    
        <!-- 下面的inclued将选择将bean的属性公布于客户使用,不写的话将所有的属性公布于客户端-->    
        <param name="include" value="id,name"/>    
    </convert>    
      </allow>    
</dwr>  
 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值