DWR之DWR实例(1)

2024-03-11 19:32
文章标签 实例 dwr

本文主要是介绍DWR之DWR实例(1),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

DWR之DWR实例(1)
----------

1.首先向项目中加入dwr.jar文件,这里我们使用maven构建,同时dwr还要依赖commons-logging.jar包,如例(pom.xml):

[html] view plain copy print ?
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>aaa</groupId>
<artifactId>bbb</artifactId>
<packaging>war</packaging>
<version>0.0.1-SNAPSHOT</version>
<name>bbb Maven Webapp</name>
<url>http://maven.apache.org</url>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<!-- 必需的依赖 -->
<dependency>
<groupId>org.directwebremoting</groupId>
<artifactId>dwr</artifactId>
<version>3.0.M1</version>
</dependency>
<!-- 必需的依赖 -->
<dependency>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
<version>1.1.1</version>
</dependency>
</dependencies>
<build>
<finalName>bbb</finalName>
</build>
</project>


2.在web.xml文件中增加DWRSevlet的配置,DWR指定映射路径的js(如:带有/dwr)都由这个servlet处理,就像这些路径的js(带有/dwr的路径):

[html] view plain copy print ?
<script src='/[YOUR-WEBAPP-CONTEXT]/dwr/interface/[YOUR-SCRIPT].js'></script>
<script src='/[YOUR-WEBAPP-CONTEXT]/dwr/engine.js'></script>

这两个件都是虚拟文件,并不是真实的文件。

web.xml的配置如下:

[html] view plain copy print ?
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
version="2.4">
<display-name>firstDWR</display-name>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
<!-- The DWR Servlet... -->
<servlet>
<display-name>DWR Servlet</display-name>
<servlet-name>dwr-invoker</servlet-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>crossDomainSessionSecurity</param-name>
<param-value>false</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>dwr-invoker</servlet-name>
<url-pattern>/dwr/*</url-pattern>
</servlet-mapping>
</web-app>


3.创建dwr.xml文件(与web.xml在同一个目录):

[html] view plain copy print ?
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE dwr PUBLIC 
"-//GetAhead Limited//DTD Direct Web Remoting 3.0//EN" "http://getahead.org/dwr/dwr30.dtd">
<dwr>
<allow>
<create creator="new" javascript="MathDelegate">
<param name="class" value="app.MathDelegate" />
</create>
</allow>
</dwr>


4.创建java文件,如:MathDelegate.java文件:

[java] view plain copy print ?
package app;
/**
* 数值计算
* @author fuhd
*/
public class MathDelegate {
/**加法*/
public int add(int a,int b){
return a+b;
}
/**减法*/
public int subtract(int a,int b){
return a-b;
}
/**乘法*/
public int multiply(int a,int b){
return a*b;
}
/**除法*/
public int divide(int a,int b){
return a/b;
}
}

5.创建jsp文件(可以是html或其它模板的文件),如:index.jsp :

[html] view plain copy print ?
  1. <html>  
  2.     <head>  
  3.         <title>firstdwr</title>  
  4.         <script type="text/javascript" src="dwr/interface/MathDelegate.js"></script>  
  5.         <script type="text/javascript" src="dwr/engine.js"></script>  
  6.         <script>  
  7.             var a = 0;  
  8.             var b = 0;  
  9.             var op = "";  
  10.             function doMath(){  
  11.                 a = document.getElementById("numA").value;  
  12.                 b = document.getElementById("numB").value;  
  13.                 op = document.getElementById("op").value;  
  14.                 if(op == "add"){  
  15.                     MathDelegate.add(a,b,doMathCallback);  
  16.                     op = "+";  
  17.                 }else if(op == "subtract"){  
  18.                     MathDelegate.subtract(a,b,doMathCallback);  
  19.                     op = "-";  
  20.                 }else if(op == "multiply"){  
  21.                     MathDelegate.multiply(a,b,doMathCallback);  
  22.                     op = "*";  
  23.                 }else if(op == "divide"){  
  24.                     MathDelegate.divide(a,b,doMathCallback);  
  25.                     op = "/";  
  26.                 }  
  27.             }  
  28.             var doMathCallback = function(answer){  
  29.                 document.getElementById("resultDiv").innerHTML = "<h1>" +   
  30.                     "Result: " + a + " " + op + " " + b + " = " + answer + "</h1>";  
  31.             };  
  32.         </script>  
  33.     </head>  
  34.     <body>  
  35.         <span id="resultDiv"></span>  
  36.         Please enter two numbers,select an operation,and click the equals button:  
  37.         <br><br>  
  38.         <input type="text" id="numA" size="4"/>  
  39.            
  40.         <select id="op">  
  41.             <option value="add">+</option>  
  42.             <option value="subtract">-</option>  
  43.             <option value="multiply">*</option>  
  44.             <option value="divide">/</option>  
  45.         </select>  
  46.            
  47.         <input type="text" id="numB" size="4"/>  
  48.            
  49.         <input type="button" value="=" onclick="doMath();"/>  
  50.     </body>  
  51. </html> 

转自:http://blog.csdn.net/fhd001/article/details/7063281

dwr官网下载地址:http://directwebremoting.org/dwr/downloads/index.html

这篇关于DWR之DWR实例(1)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/798841

相关文章

MyBatis-Plus中Service接口的lambdaUpdate用法及实例分析

《MyBatis-Plus中Service接口的lambdaUpdate用法及实例分析》本文将详细讲解MyBatis-Plus中的lambdaUpdate用法,并提供丰富的案例来帮助读者更好地理解和应... 目录深入探索MyBATis-Plus中Service接口的lambdaUpdate用法及示例案例背景

MyBatis-Plus中静态工具Db的多种用法及实例分析

《MyBatis-Plus中静态工具Db的多种用法及实例分析》本文将详细讲解MyBatis-Plus中静态工具Db的各种用法,并结合具体案例进行演示和说明,具有很好的参考价值,希望对大家有所帮助,如有... 目录MyBATis-Plus中静态工具Db的多种用法及实例案例背景使用静态工具Db进行数据库操作插入

Spring中@Lazy注解的使用技巧与实例解析

《Spring中@Lazy注解的使用技巧与实例解析》@Lazy注解在Spring框架中用于延迟Bean的初始化,优化应用启动性能,它不仅适用于@Bean和@Component,还可以用于注入点,通过将... 目录一、@Lazy注解的作用(一)延迟Bean的初始化(二)与@Autowired结合使用二、实例解

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

mysqld_multi在Linux服务器上运行多个MySQL实例

《mysqld_multi在Linux服务器上运行多个MySQL实例》在Linux系统上使用mysqld_multi来启动和管理多个MySQL实例是一种常见的做法,这种方式允许你在同一台机器上运行多个... 目录1. 安装mysql2. 配置文件示例配置文件3. 创建数据目录4. 启动和管理实例启动所有实例

Java function函数式接口的使用方法与实例

《Javafunction函数式接口的使用方法与实例》:本文主要介绍Javafunction函数式接口的使用方法与实例,函数式接口如一支未完成的诗篇,用Lambda表达式作韵脚,将代码的机械美感... 目录引言-当代码遇见诗性一、函数式接口的生物学解构1.1 函数式接口的基因密码1.2 六大核心接口的形态学

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

Java操作ElasticSearch的实例详解

《Java操作ElasticSearch的实例详解》Elasticsearch是一个分布式的搜索和分析引擎,广泛用于全文搜索、日志分析等场景,本文将介绍如何在Java应用中使用Elastics... 目录简介环境准备1. 安装 Elasticsearch2. 添加依赖连接 Elasticsearch1. 创

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

Oracle Expdp按条件导出指定表数据的方法实例

《OracleExpdp按条件导出指定表数据的方法实例》:本文主要介绍Oracle的expdp数据泵方式导出特定机构和时间范围的数据,并通过parfile文件进行条件限制和配置,文中通过代码介绍... 目录1.场景描述 2.方案分析3.实验验证 3.1 parfile文件3.2 expdp命令导出4.总结