zoukankan      html  css  js  c++  java
  • 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=" 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("操作失败!");
    }
  • 相关阅读:
    ueditor实现ctrl+v粘贴word图片并上传
    fckeditor实现ctrl+v粘贴word图片并上传
    kindeditor实现ctrl+v粘贴word图片并上传
    ckeditor实现ctrl+v粘贴word图片并上传
    html大文件传输功能
    html大文件传输解决方案
    html大文件传输教程
    html大文件传输方案
    PDI(Kettle)的使用六 kitchen
    PDI(Kettle)的使用五 Pan
  • 原文地址:https://www.cnblogs.com/java-class/p/6653739.html
Copyright © 2011-2022 走看看