Dwr 架構簡單一實例,dwr架構執行個體
Dwr 是一個 Java 開源庫,協助你實現Ajax網站。
它可以讓你在瀏覽器中的Javascript代碼調用Web伺服器上的Java,就像在Java代碼就在瀏覽器中一樣。
Dwr 主要包括兩部分:
在伺服器上啟動並執行 Servlet 來處理請求並把結果返回瀏覽器。
運行在瀏覽器上的 Javascript,可以發送請求,並動態改變頁面。
Dwr 會根據你的 Java 類動態產生Javascript代碼。
這些代碼的魔力是讓你感覺整個Ajax調用都是在瀏覽器上發生的,但事實上是伺服器執行了這些代碼,DWR負責資料的傳遞和轉換。
從DWR官網下載最新版本的jar包,地址:http://directwebremoting.org/dwr/downloads/index.html
將jar包放入WEB-INF的lib檔案夾下。同時,dwr依賴於commons-logging.jar這個包
配置 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>
配置 dwr 如下
<?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> <create creator="new" javascript="Chat"> <param name="class" value="com.epri.xts.wxqyh.app.chatroom.module.Chat"/> </create> <convert converter="bean" match="com.epri.xts.wxqyh.app.chatroom.bean.Message"/> </allow></dwr><!-- <!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 1.0//EN" "http://www.getahead.ltd.uk/dwr/dwr10.dtd"> <!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 2.0//EN" "http://www.getahead.ltd.uk/dwr/dwr20.dtd">-->
dwr.xml 是 dwr 的核心設定檔,主要的標籤有:<converter>、<convert>、<create>這三個標籤。
<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+)
這裡初學,實用java new建立對象。
4、頁面配置
頁面需要引入3個JS
<script src="<%=ctxPath%>/dwr/interface/Chat.js" type="text/javascript"></script><script src="<%=ctxPath%>/dwr/engine.js" type="text/javascript"></script><script src="<%=ctxPath%>/dwr/util.js" type="text/javascript"></script>
其中 engine.js 必須要,如果需要用到dwr提供的一些方便的工具要引用util.js ,然後是dwr自動產生的js檔案。
名字和 dwr.xml 中 create 標籤的 javascript 屬性值一樣,且必須是 dwr/interface 開頭的目錄
5、javascript代碼:
// 發送訊息function sendMessage() { var text = DWRUtil.getValue("message"); if("" != text){ DWRUtil.setValue("message", ""); Chat.addMessage(text, name, taskId, gotMessages); }}function gotMessages(messages) { var chatlog = ""; for ( var data in messages) { chatlog = "<div> <li class='even'>" + messages[data].text + "</li></div } DWRUtil.setValue("chatlog", chatlog); setTimeout("queryMessage()", 2000);}function queryMessage() { Chat.getMessages(taskId, gotMessages);}
html代碼
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%><!DOCTYPE html><% String ctxPath = request.getContextPath();%><html><head><title>聊天組</title><meta charset="utf-8"><meta name="viewport" content="width=device-width, initial-scale=1"><link rel="stylesheet" href="../css/jquery.mobile-1.4.5.min.css"><link rel="stylesheet" type="text/css" href="../css/bootstrap.min.css"><link rel="stylesheet" href="../css/add.css"><script src="../js/jquery-1.8.3.min.js"></script><script src="../js/jquery.mobile-1.4.5.min.js"></script></head><body class="bgc" onload="queryMessage()"> <div data-role="page" id="pageone"> <!-- 聊天內容顯示地區 --> <div data-role="content" class="container" role="main"> <ul class="content-reply-box mg10" id="chatlog"> </ul> </div> <!-- 下方輸入框 --> <div data-position="fixed" data-role="footer"> <ul class="footer"> <li class="col-xs-3"> <span class="b_pic"> <form action="<%=request.getContextPath()%>/chat" method="post" enctype="multipart/form-data" data-ajax="false" name="form" id="form" target="relnews"> <input type="hidden" name="name" id="name" value="" /> <input type="hidden" name="taskId" id="taskId" value="" /> <input type="file" name="image" id="image" class="photo" onchange="sendImage(this)" /> </form> </span> </li> <li class="col-xs-6"><input type="text" name="fname" id="message"></li> <li class="col-xs-4"><a href="" data-role="button" class="b_submit" id="submitInfo" onclick='sendMessage();'>發送</a></li> </ul> </div> </div> <!-- 隱藏欄位作為表單提交後頁面不跳轉使用 --> <iframe align="center" frameborder="0" marginheight="0" marginwidth="0" name="relnews" id="hiddenIframe" scrolling="no" style="width: 100%; height: 100%; display: none"> </iframe> </body><script src="<%=ctxPath%>/dwr/interface/Chat.js" type="text/javascript"></script><script src="<%=ctxPath%>/dwr/engine.js" type="text/javascript"></script><script src="<%=ctxPath%>/dwr/util.js" type="text/javascript"></script><script type="text/javascript" src="../js/chat.js"></script></html>
6、其他
dwr可以設定是否採用非同步方式訪問java代碼:
dwr.engine.setAsync(false); //false為同步,true(預設)為非同步以及dwr對於異常的處理,這裡標註一個簡單的全域異常,細分的後續學習補充:dwr.engine.setErrorHandler(errh);function errh(errorString, exception) { errorFlag = true; alert("操作失敗!");}