zoukankan      html  css  js  c++  java
  • AJaxPro 与 DWR 的研究与比较

    1、DWR: Easy AJAX for JAVA

    作为一个java open source library,DWR可以帮助开发人员完成应用AJAX技术的web程序。它可以让浏览器上的javascript方法调用运行在web服务器上java方法。

    DWR主要由两部门组成。javascript与web服务器通信并更新web页;运行在web服务器的Servlet处理请求并把响应发回浏览器。

    DWR采用新颖的方法实现了AJAX(本来也没有确切的定义),在java代码基础上动态的生成javascript代码。web开发者可以直接调用这些javascript代码,然而真正的代码是运行在web服务器上的java code。出与安全考虑,开发者必须配置哪些java class暴露给DWR.(dwr.xml)

    这种从(java到javascript)调用机制给用户一种感觉,好象常规的RPC机制,或RMI or SOAP.但是它运行在web上,不需要任何浏览器插件。

    DWR不认为浏览器和web服务器之间协议重要,把系统界面放在首位。最大挑战是java method call的同步特征与ajax异步特性之间的矛盾。在异步模型里,结果只有在方法结束后才有效。DWR解决了这个问题,把回调函数当成参数传给方法,处理完成后,自动调用回调方法。

    通过javascript事件,DWR能改变select的内容,当然这些内容由java代码返回。 javascript函数Data.getOptions(populateList)由DWR动态生成,这个函数会调用java class Data类的方法。DWR处理如何远程调用,包括转换所有的参数和返回的结果(javascript\java)。java方法执行完后,执行回调方法populateList。在整个过程中我们就想在用本地的方法一样。

    2、Getting Started

     
    web.xml
    <?xml version="1.0" encoding="ISO-8859-1"?>
    <!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd">

    <web-app id="dwr">
      <servlet>
        <servlet-name>dwr-invoker</servlet-name>
        <servlet-class>uk.ltd.getahead.dwr.DWRServlet</servlet-class>
      </servlet>
      <servlet-mapping>
        <servlet-name>dwr-invoker</servlet-name>
        <url-pattern>/dwr/*</url-pattern>
      </servlet-mapping>
    </web-app>

    dwr.xml  与web.xml同目录
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 1.0//EN" "http://www.getahead.ltd.uk/dwr/dwr10.dtd">
    <dwr>
      <allow>
        <create creator="new" javascript="JDate">
          <param name="class" value="java.util.Date"/>
        </create>
      </allow>
    </dwr>

    index.html
    <html>
    <head>
      <title>DWR - Test Home</title>
      <script type='text/javascript' src='dwr/interface/JDate.js'></script>
      <script type='text/javascript' src='dwr/engine.js'></script>
      <script>
        function init(){
            JDate.getYear(load);
        }
        function load(data){
          alert(data+1900+'年')
        }
      </script>
    </head>
    <body onload="init()">
    </body>
    </html>

    dwr.jar  下载放lib下

    完了,什么,够了,就这些。访问ok!
    3、Examples
    http://www.aboutmyhealth.org/  这不是Google Suggest吗!ok.
    4、源码浅析
    dwr的设计很象webwork2的设计,隐藏http协议,扩展性,兼容性及强。

    通过研究uk.ltd.getahead.dwr.DWRServlet这个servlet来研究下dwr到底是如何工作滴。

    Code

    AjaxPro

    1.GetStart

    点击一个客户端button,触发一个javascript函数,执行一个只有一个string参数的服务端方法,返回一个处理过的string,处理方法是将传入的string变成“Hi”+string +“!”,很简单的一个例子。

    服务器端代码如下:

    Code

    页面代码:

    Code

    2.分析

    如果你已经成功运行,那么查看客户端源文件,你会发现多出下面的几个脚本

    <script type="text/javascript" src="/AJAXDemo.2/ajaxpro/prototype.ashx"></script>
    <script type="text/javascript" src="/AJAXDemo.2/ajaxpro/core.ashx"></script>
    <script type="text/javascript" src="/AJAXDemo.2/ajaxpro/converter.ashx"></script>
    <script type="text/javascript" src="/AJAXDemo.2/ajaxpro/AJAXDemo.Examples.Test.TestMethod,App_Code.urx4hqkg.ashx"></script>


    通过使用http://localhost:3578/AJAXDemo.2/ajaxpro/prototype.ashx和http: //localhost:3578/AJAXDemo.2/ajaxpro/core.ashx不难发现,其中前面两个是源代码中带的两个js文件(core.js和prototype.js)转化出来的,

    .net运行框架调用以下方法:
    AjaxHandlerFactory.GetHandler
    1.由于.ashx被注册为自定义处理,此方法被调用4次;
    2.依据请求类型(get)和请求的目标进行分别处理,分别对应EmbeddedJavaScriptHandler(2次),ConverterJavaScriptHandler(1次),TypeJavaScriptHandler(1次)
    3..net运行框架在AjaxHandlerFactory.GetHandler返回不同的IHttpHandler实现(EmbeddedJavaScriptHandler等)时调用该实现的以下方法:
    EmbeddedJavaScriptHandler.ProcessRequest方法被调用:
    EmbeddedJavaScriptHandler.ProcessRequest方法被调用:
    ConverterJavaScriptHandler.ProcessRequest方法被调用:
    TypeJavaScriptHandler.ProcessRequest方法被调用:
    向客户端输出JavaScript 对象和方法的接口

    基本内容也跟原来的文件一样,而converter.ashx和 AJAXDemo.Examples.Test.TestMethod,App_Code.urx4hqkg.ashx里面有什么呢?看下面代码:

    Code

    //当用户触发表现层控件动作事件
    1.由于生成的客户端脚本中包含对于"/AJAXDemo.Examples.Test.TestMethod,App_Code.urx4hqkg.ashx"的调用,导致AjaxHandlerFactory.GetHandler被调用
    2.在AjaxHandlerFactory.GetHandler中返回AjaxSyncHttpHandler
    3..net运行框架在AjaxHandlerFactory.GetHandler返回不同的IHttpHandler实现(AjaxSyncHttpHandler等)时调用该实现的以下方法:
    AjaxSyncHttpHandler.ProcessRequest方法被调用:
    将调用转嫁到AjaxProcHelper.Run操作:
    1.通过反射实现对指定C#类方法的调用.
    2.将反射调用结果通过XmlHttpRequestProcessor.SerializeObject中对JavaScriptSerializer.Serialize的调用,通过Response向客户端返回. 

    研究完AjaxPro 和DWR 的机制,个人总结了一些比较;

    1.AjaxPro 面向对后台方法的访问,针对的是带有Public,Private的方法,而不是具体类,DWR中没有这样的限制,它是对JAVA类的整体反射,对所有方法生成javascript 接口方法,当然,你也可以选择继承它的反射类,按自己的需求自定义一个代理接口供DWR来反射,毕竟,这是开源的一大优势。但总的来说,AjaxPro比DWR考虑的更安全,更精细。

    2.DWR中继承了Spring的思想,灵活运用Reflect和配置文件,使应用程序的扩展性更强,更灵活。

    3.AjaxPro 针对某个具体的业务实现需要进行后台的配置,如加入【AjaxPro.Method】,为每个Code Behind 写入一个页面注册事件

    AjaxPro.Utility.RegisterTypeForAjax(typeof(_Default)); //_Default 为页面的后台代码类

    试想一下,如果你有很多这样的Ajax业务应用,而每个页面都需要这样注册,是不是很繁琐?交叉业务的维护呢……

    而DWR将一个业务应用的JAVA Class 转换成JavaScript,不需要对JAVA Model 有任何操作,只需在配置文件dwr.xml中create.简单,便于维护,特别是在大的项目中跟能体现。

  • 相关阅读:
    将数据挂载到 docker 容器中的3种方式:volume、bind mount、tmpfs
    kubectl 常用命令
    Kubernetes 知识点
    spring boot 学习资料
    docker 常见系统镜像
    docker 的前台模式和后台模式
    Docker容器里的进程为什么要前台运行?相同的问题:docker运行apache为什么带FOREGROUND参数?docker运行nginx为什么带`daemon off`参数?
    spring cloud 各核心组件作用
    nginx 镜像使用说明
    optimization.splitChunks 中,chunks 的3个值:all、async、initial 的含义
  • 原文地址:https://www.cnblogs.com/ysisl/p/1507302.html
Copyright © 2011-2022 走看看