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("操作失败!");
}
时间: 2024-07-28 14:53:30

Dwr 框架简单实例的相关文章

Web端服务器推送技术原理分析及dwr框架简单的使用

1 背景 “服务器推送技术”(ServerPushing)是最近Web技术中最热门的一个流行术语.它是继“Ajax”之后又一个倍受追捧的Web技术.“服务器推送技术”最近的流行跟“Ajax ”有着密切的关系. 随着 Ajax技术的兴起,让广大开发人员又一次看到了使用浏览器来替代桌面应用的机会,并且这次机会非常大.Ajax将整个页面的刷新变成页面局部的刷新,并且数据的传送是以异步方式进行,这使得网络延迟带来的视觉差异将会消失. 但是,在浏览器中的 Ajax应用中存在一个致命的缺陷无法满足传统桌面系

Web端服务器推送技术原理分析及dwr框架简单的使用 转载

1 背景 “服务器推送技术”(ServerPushing)是最近Web技术中最热门的一个流行术语.它是继“Ajax”之后又一个倍受追捧的Web技术.“服务器推送技术”最近的流行跟“Ajax ”有着密切的关系. 随着 Ajax技术的兴起,让广大开发人员又一次看到了使用浏览器来替代桌面应用的机会,并且这次机会非常大.Ajax将整个页面的刷新变成页面局部的刷新,并且数据的传送是以异步方式进行,这使得网络延迟带来的视觉差异将会消失. 但是,在浏览器中的 Ajax应用中存在一个致命的缺陷无法满足传统桌面系

EntityFramework 实体框架简单实例

此实例在VS2012环境下,未安装实体框架包.直接添加来完成. 第一步:添加类库,浏览类库文件. 第二步:添加实体数据模型 第三步:配置实体数据模型 注意:这步要选择配置的数据表,并且将确定所生产对象名称的单复数形式勾选. 添加成功后,则在解决方案中显示已经添加成功的框架模型. 配置文件中自动添加了一下内容: <connectionStrings> <add name="Entities" connectionString="metadata=res://*

spring+springMvc+hibernate框架简单实例

配置文件: web.xml <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml

spring+springMvc+mybatis框架简单实例

web.xml <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/ja

dwr框架异步调用简单小例

DWR(Direct Web Remoting)是一个用于改善web页面与Java类交互的远程服务器端Ajax开源框架.可以轻松实现用js直接调用java方法. 通过一个小例子来演示一个dwr的基本使用: ①. 首先肯定要创建一个web project的,然后拷贝dwr.jar到WEB-INF\lib目录下 ②. 修改web.xml文件,添加dwr servlet配置 <servlet> <servlet-name>dwr-invoker</servlet-name>

SpringMVC笔记——SSM框架搭建简单实例

落叶枫桥 博客园 首页 新随笔 联系 订阅 管理 SpringMVC笔记——SSM框架搭建简单实例 简介 Spring+SpringMVC+MyBatis框架(SSM)是比较热门的中小型企业级项目开发的框架,对于新手来说也是比较容易学习入门的.虽说容易,但在框架搭建过程中仍然遇到了许多问题,因此用实例记录下来吧. 实例 第一步——导包 Spring框架包及其依赖包 MyBatis框架包及其依赖包 MyBatis-EhCache架包 C3P0架包 MySql数据库驱动包 项目架包如下: 项目结构如

DWR简单实例

首先要导入DWR的jar包,同时导入common-logging包.DWR包的下载地址:http://directwebremoting.org/dwr/downloads/index.html  里面也有demo下载,有DWR的其他实例,我这里记录DWR最简单的一种Ajax技术. 导入dwr.jar和common-logging.jar后,在web.xml文件中加入DWRServlet: <!-- 加入DWRServlet -->   <servlet>           &l

DWR之入门实例(一)

DWR(Direct Web Remoting)是一个WEB远程调用框架.利用这个框架可以让AJAX开发变得很简单.利用DWR可以在客户端利用JavaScript直接调用服务端的Java方法并返回值给JavaScript就好像直接本地客户端调用一样(DWR根据Java类来动态生成JavaScrip代码).它的最新版本DWR0.6添加许多特性如:支持Dom Trees的自动配置,支持Spring(JavaScript远程调用spring bean),更好浏览器支持,还支持一个可选的commons-