当前位置: 代码迷 >> Web前端 >> dwr 施用简介
  详细解决方案

dwr 施用简介

热度:493   发布时间:2013-05-02 09:39:29.0
dwr 使用简介

dwr:
??? 安装 DWR 时会配置一个 servlet ,他就是负责把前台的JS参数封装成JAVA,
??? 去调用你的JAVA类,然后将返回结果(JAVA类型)再翻译成JS生成到你的JSP页面上,
??? 给你的错觉就是你用JS直接调用了JAVA方法。

使用步骤:
??? 1.在Web.xml中配置 DWRServlet ,在服务器启动时初始化 dwr 引擎。
??? 2.在dwr.xml中配置 可以供dwr使用的类的映射。
???????
??? 3.jsp 中引入提供给 dwr 使用的映射类。
??? 4.使用 配置的映射 名称,调用相应的类。
???
web.xml:
???

<servlet>
        <servlet-name>dwr-invoker</servlet-name>
        <display-name>DWR Servlet</display-name>
        <servlet-class>org.directwebremoting.servlet.DwrServlet</servlet-class>
        <init-param>
            <param-name>debug</param-name>
            <param-value>true</param-value>
        </init-param>
        <init-param>
            <param-name>classes</param-name>
            <param-value>java.lang.Object</param-value>
        </init-param>
    </servlet>
   
    <servlet-mapping>
        <servlet-name>dwr-invoker</servlet-name>
        <url-pattern>/dwr/*</url-pattern>
    </servlet-mapping>

?
???
dwr.xml
??? deploy\taishan_assets.war\WEB-INF\dwr.xml
??? create: 配置一个 类,dwr会生成一个对应的 js 脚本,用来关联 js 方法与 java 方法。
???

<?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 2.0//EN" "http://getahead.org/dwr/dwr20.dtd">
    <dwr>
        <allow>
            <convert match="gds.equipment.base.ExtendPropertyDTO" converter="bean"/>

            <!-- dwr将该类解析成的js文件名称,调用该js中的方法,就会调用该类的相应方法。 -->
            <create creator="new" javascript="ManageDeviceService">
                <!-- 提供给dwr使用的类 -->
                <param name="class" value="gds.equipment.device.business.ManageDeviceService"/>
            </create>
        </allow>
    </dwr>

?

jsP:

    <%--  Ajax 与 服务器端交互的 API -->
    <script type='text/javascript' src='<%=request.getContextPath()%>/dwr/engine.js'></script>
    <%-- 提供的工具类 -->
    <script type='text/javascript' src='<%=request.getContextPath()%>/dwr/util.js'></script>
    <%-- 引入对应的 java 映射 js 文件 -->
    <script type='text/javascript' src='<%=request.getContextPath()%>/dwr/interface/ManageDeviceService.js'></script>
        

?
js调用Java方法:
??? js :?????? ManageDeviceService.checkDeviceCodeIsNew(obj.value, chkCodeIsNew);
??? java :???? public boolean checkDeviceCodeIsNew(String aDeviceCode) throws Exception
???
??? js中的最后一个参数是 回调函数。
??? 不管 Java 方法中有几个参数,只要js给够就行了,然后要在后面加一个回调函数。
??? 回调函数的参数 就是 Java方法的返回值。
???
dwr请求处理:
??? 在web.xml 中配置 /dwr/* 请求路径后,凡是以该头部开始的请求都会发送到? DwrServlet 类中。
??? 该类会针对路径中存在的路径区别处理。
??? DWRServlet.doGet, doPost方法都调用 processor.handle(req, resp)方法处理。
??? Processor对象在init()方法中已经初始化了。?
??? handle方法:
???????

public void handle(HttpServletRequest req, HttpServletResponse resp); 
            throws IOException 
        { 
            String pathinfo = req.getPathInfo();; 
            if(pathinfo == null || pathinfo.length(); == 0 || pathinfo.equals("/");); 
            { 
                resp.sendRedirect(req.getContextPath(); + req.getServletPath(); + '/' + "index.html");; 
            } else 
            if(pathinfo != null && pathinfo.equalsIgnoreCase("/index.html");); 
            { 
                doIndex(req, resp);; 
            } else 
            if(pathinfo != null && pathinfo.startsWith("/test/");); 
            { 
                doTest(req, resp);; 
            } else 
            if(pathinfo != null && pathinfo.equalsIgnoreCase("/engine.js");); 
            { 
                doFile(resp, "engine.js", "text/javascript");; 
            } else 
            if(pathinfo != null && pathinfo.equalsIgnoreCase("/util.js");); 
            { 
                doFile(resp, "util.js", "text/javascript");; 
            } else 
            if(pathinfo != null && pathinfo.equalsIgnoreCase("/deprecated.js");); 
            { 
                doFile(resp, "deprecated.js", "text/javascript");; 
            } else 
            if(pathinfo != null && pathinfo.startsWith("/interface/");); 
            { 
                doInterface(req, resp);; 
            } else 
            if(pathinfo != null && pathinfo.startsWith("/exec");); 
            { 
                doExec(req, resp);; 
            } else 
            { 
                log.warn("Page not found. In debug/test mode try viewing /[WEB-APP]/dwr/");; 
                resp.sendError(404);; 
            } 
        }

?
??? dwr/*处理的请求也就这几种。?
??? (1)dwr/index.html,dwr/test/这种只能在debug模式下使用,调试用。?
??????? dwr/engine.js,dwr/util.js,dwr/deprecated.js当这个请求到达,
??????? 从dwr.jar包中读取文件流,响应回去。(重复请求有缓存)?
??? (2)当dwr/interface/这种请求到来,(例如我们在index.html中的
??????? <script type='text/javascript' src='dwr/interface/JDate.js'></script>)
??????? DWR 把我们在WEB-INF/dwr.xml中的?
??????? <create creator="new" javascript="JDate">?
????????????? <param name="class" value="java.util.Date"/>?
??????? </create>?
??? java.util.Date转化为javascript函数。?
??????? http://localhost:port/simpledwr/dwr/interface/JDate.js看看吧。?
??? 细节也比较简单,通过java反射,把方法都写成javascript特定的方法。
??? (3)dwr/exec?
??????? javascript调用方法时发送这种请求,可能是XMLHttpRequest或IFrame发送。?
??? 当然,javascript调用的方法签名与java代码一致,包括参数,
??? 还有javascript的回调方法也传到了服务器端,在服务器端很容易实现。
??? 回调方法的java的执行结果 返回类似
??? <script>callMethod(结果)<script>的javascript字符串,在浏览器执行。
?????
??? dwr的设计构思很是巧妙。?
??? 第一、把java类转化为javascript类由dwr自动完成,只需简单的配置。?
??? 第二、应用起来极其简单。开发者不要该服务器代码就可以集成。?
??? 第三、容易测试。和webwork一样,隐藏的http协议。?
??? 第四、及强扩展性。例如与spring集成,只需修改一点代码。?
??? 第五、性能。就我与jason,等简单比较,dwr性能可能是最好的。?
??? 第六、自动把java对象转化为javascript对象,并且及易扩展。?
???????
查看 dwr 转换的js 文件:
??? http://server:port/projectName/dwr/interface/*dwr.xml中配置的Java类映射名称*.js

  相关解决方案