DWR搭建以及使用教程

jopen 12年前發布 | 147K 次閱讀 DWR Ajax框架

DWR(Direct Web Remoting)是一個Ajax的開源框架,用于改善web頁面與Java類交互的遠程服務器端的交互體驗,可以幫助開發人員開發包含AJAX技術的網站。它可以允許在瀏覽器里的代碼使用運行在WEB服務器上的JAVA函數,就像它就在瀏覽器里一樣。

  從DWR官網下載最新版本的jar包,地址:http://directwebremoting.org/dwr/downloads/index.html

  將jar包放入WEB-INF的lib文件夾下。同時,dwr依賴于commons-logging.jar這個包,所以必須將這個jar包也放入到WEB-INF的lib文件夾相愛。

  

  首先是配置dwr的環境:

  1. web.xml文件:

<servlet>
  <servlet-name>dwr-invoker</servlet-name>
  <servlet-class>uk.ltd.getahead.dwr.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>

  2. 從官網的jar.war文件中利用winRAR等軟件提取出dwr.xml文件,并將其放入到WEB-INF文件夾下。

  dwr.xml是dwr的核心配置文件,主要的標簽有:<converter>、<convert>、<create>這三個標簽。

  <converter>標簽是dwr中內置的轉換器。我們也可以使用自己寫的轉換器,不過dwr提供的轉換器已經足夠了,所以這個標簽,一般不會自己去寫。

  <convert>標簽是將converter中定義的轉換器映射到的具體類型,如:

<converter id="date"class="org.directwebremoting.convert.DateConverter"/> <!-- 注冊了 date 轉換器 -->
<!-- 注意:converter標簽必須放到<init>標簽內,而convert是放在<allow>標簽內,這里只是示例,并不是完整的dwr.xml -->
<convert converter="date"match="java.util.Date"/> <!-- 將注冊的 date 轉換器應用到 java.util.Date 類型
 -->

  <create>標簽是dwr中重要的標簽,用來描述 java(服務器端) 與 javascript (客戶端)的交互方式。其基本格式如下:

<allow>
  <create creator="..." javascript="..." scope="...">
    <param name="..." value="..."/>
    <auth method="..." role="..."/>
    <exclude method="..."/>
    <include method="..."/>
  </create>
  ...
</allow>

  其中,creator和javascript是必須屬性,其他可以忽略。creator包含有以下幾個值:

  new:Java用“new”關鍵字創造對象

  none:它不創建對象  (v1.1+)

  scripted:通過BSF使用腳本語言創建對象,例如BeanShell或Groovy

  spring:通過Spring框架訪問Bean

  struts:使用Struts的FormBean  (v1.1+)

  jsf:使用JSF的Bean  (v1.1+)

  pageflow:訪問Weblogic或Beehive的PageFlow  (v1.1+)

  ejb3:使用EJB3 session bean  (v2.0+)

  關于這幾個屬性如何使用,這里就不在詳細闡述了。我只列出一個與spring整合的例子:

  

<create creator="spring" javascript="backUpDocumentService">
  <param name="beanName" value="testDWR1" />
  <include method="modifyBackUpFiles"></include>
  <include method="isSafeCodeRight"></include>
</create>

<!-- 加include可以具體指定java類中關的方法,不加則默認類中全部為public的方法 -->     
<create creator="spring" javascript="testDWR2">
  <param name="beanName" value="testDWR2" />
</create>

   spring配置文件

<bean id="testDWR1" class="com.test.testDWR1"></bean>
<bean id="testDWR2" class="com.test.testDWR2"></bean>

  3. 頁面配置

  在jsp頁面添加三個 js 文件,分別是

<script type='text/javascript' src='js/util.js'></script>
<script type='text/javascript' src='js/engine.js'></script>
<script type='text/javascript' src='dwr/interface/testDWR1.js'>

  其中engine.js必須要,如果需要用到dwr提供的一些方便的工具要引用util.js ,然后是dwr自動生成的js文件,名字必須和dwr.xml中create標簽的javascript屬性值一樣,且是dwr/interface開頭的目錄

  4. 接下來就可以分別寫javascript和java代碼了。

  javascript代碼:

function testFun() {
    var name = "aaaaa";
    testDWR1.testFun(name, returnFun);  //調用java方法,第二個參數是回調函數
}function returnFun(data) {  //data對應著java方法的返回值
    alert(data);
}

   java代碼:

package com.test;

public class testDWR1 {
    public String test(String str) {
        str += "bbb";
        return str;
    }
}

   5.  其他

  dwr可以設置是否采用異步方式訪問java代碼,其代碼為:

dwr.engine.setAsync(false);  //false為同步,true(默認)為異步

  以及dwr對于異常的處理,這里我只列出個簡單的全局性異常捕獲,具體到針對某個方法的異常捕獲,大家可以自己上網找找。

dwr.engine.setErrorHandler(errh);
function errh(errorString, exception) {
    errorFlag = true;
    alert("操作失敗!");
}

  dwr同樣支持參數為對象的方法,這需要在dwr.xml中配置下<convert>標簽:

<convert converter="bean" match="com.example.Person"/>

  那么關于dwr我也只介紹到這里了,這基本就是dwr的基本內容了,可以滿足普通的項目需求了。

  想進一步對于dwr的深入可以查詢下相關文章或查看api,這里我就不再說的那么詳細了。

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!