1,从官方网站下载DWR https://dwr.dev.java.net/files/documents/2427/32252/dwr.war 把他直接放到TOMCAT_HOME/webapps 下面
2,编写一个Java类如下:
package org.getahead.dwrdemo.simpletext;
import java.io.IOException;
import javax.servlet.ServletException;
import org.directwebremoting.WebContext;
import org.directwebremoting.WebContextFactory;
/**
* Some simple text demos
* @author Joe Walker [joe at getahead dot ltd dot uk]
*/
public class Demo
{
/**
* Return a server side string to display on the client in real time
* @param name The name of person to say hello to
* @return A demo string
*/
public String sayHello(String name)
{
return "Hello, " + name;
}
/**
* Fetch a resource using forwardToString()
* @return a demo HTML page
* @throws ServletException If the servlet engine breaks
* @throws IOException If the servlet engine breaks
*/
public String sayBye(String name){
return "bye-bye,"+name;
}
public String sayWelcome(){
return "welcome";
}
public String showTitle(String name,String title){
return name+":"+title;
}
public int showNumber(){
return 1;
}
public boolean showBool(String name){
if(name==null){
name="";
}
if(name.indexOf("janny")!=-1){
return true;
}else{
return false;
}
}
public String getInclude() throws ServletException, IOException
{
WebContext wctx = WebContextFactory.get();
return wctx.forwardToString("simpletext/forward.html");
}
}
3, 把DRWTest类配置在dwr.xml中,dwr.xml是DWR的配置文件,所有需要在JavaScript中调用的java的类都必须在这个文件中描述 。这个文件的位于TOMCAT_HOME/webapps/dwr/WEB-INF/dwr.xml. 在<allow>标签中添加以下内容
<?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>
<create creator="new" javascript="Demo">
<param name="class" value="org.getahead.dwrdemo.simpletext.Demo"/>
</create>
</allow>
</dwr>
4,在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="dwrtest">
<welcome-file-list>
<welcome-file>
index.jsp
</welcome-file>
</welcome-file-list>
--------------------------------------这是必须要加的内容--------------------------------------------
<servlet>
<servlet-name>dwr-invoker</servlet-name>
<display-name>DWR Servlet</display-name>
<description>Direct Web Remoter Servlet</description>
<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>activeReverseAjaxEnabled</param-name>
<param-value>true</param-value>
</init-param>
<init-param>
<param-name>initApplicationScopeCreatorsAtStartup</param-name>
<param-value>true</param-value>
</init-param>
<init-param>
<param-name>maxWaitAfterWrite</param-name>
<param-value>500</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>dwr-invoker</servlet-name>
<url-pattern>/dwr/*</url-pattern>
</servlet-mapping>
</web-app>
5,在index。html页面里html的内容
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Simple Text Generation Demo</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<script type='text/javascript' src='../tabs/tabs.js'> </script>
<!---------------------------------------这是必须要加的内容--------------->
<script type='text/javascript' src='../dwr/engine.js'> </script>
<script type='text/javascript' src='../dwr/util.js'> </script>
<script type='text/javascript' src='../dwr/interface/Demo.js'> </script>
<!--------------------------------------------------------------------------------->
<!----------------------------------这是要修改的javascript----------------------------------------->
<script type="text/javascript" src='index.js'> </script>
<!------------------------------------------------------------------------------------------------------->
<link rel="stylesheet" type="text/css" href="../tabs/tabs.css" />
<link rel="stylesheet" type="text/css" href="../generic.css" />
</head>
<body onload="dwr.util.useLoadingMessage();Tabs.init('tabList', 'tabContents');">
<div id="page-title">[
<a href="http://getahead.org/dwr/">DWR Website</a> |
<a href="..">Web Application Index</a>
]</div>
<h1>Dynamically Updating Text</h1>
<p>This is a simple demonstration of how to dynamically update a web-page with
text fetched from a web server.</p>
<div id="demoDiv">
<p>
Name:
<input type="text" id="demoName" value="Joe"/>
<input value="Hello" type="button" onclick="hello()"/>
<input value="Bye" type="button" onclick="bye()"/>
<input value="Welcome" type="button" onclick="welcome()"/>
<input value="showTitle" type="button" onclick="showTitle()"/>
<input value="shownubmer" type="button" onclick="shownumber()"/>
<input value="showbool" type="button" onclick="showbool()"/>
<br/>
Reply: <span id="demoReply" style="background:#eeffdd; padding-left:4px; padding-right:4px;"></span>
</p>
</div>
</body>
</html>
6,index。js的修改
function hello() {
var name = dwr.util.getValue("demoName");
//注意:Demo.sayHello(name,function(data)...)是跟java类相似的
Demo.sayHello(name, function(data) {
dwr.util.setValue("demoReply", data);//这个setValue方法是dwr本身就带着
});
}
function bye() {
var name = dwr.util.getValue("demoName");
Demo.sayBye(name, function(data) {
dwr.util.setValue("demoReply", data);
});
}
function welcome() {
var name = dwr.util.getValue("demoName");
Demo.sayWelcome(function(data) {
dwr.util.setValue("demoReply", data+" to china! "+name);
});
}
function showTitle() {
var name = dwr.util.getValue("demoName");
Demo.showTitle(name,"你在北京",function(data) {
dwr.util.setValue("demoReply", data);
});
}
function shownumber() {
var name = dwr.util.getValue("demoName");
Demo.showNumber(function(data) {
dwr.util.setValue("demoReply", data);
});
}
function showbool() {
var name = dwr.util.getValue("demoName");
Demo.showBool(name,function(data) {
if(data==true){
dwr.util.setValue("demoReply", "你好呀"+name);
}else{
dwr.util.setValue("demoReply", "哭死我了"+name);
}
});
}
7, 运行,在浏览器中输入 http://localhost:8080/dwr/index.html
分享到:
相关推荐
**DWR技术** DWR(Direct Web Remoting)是一种JavaScript库,它允许Web应用程序与服务器端的Java对象进行实时通信,实现Ajax(Asynchronous JavaScript and XML)应用中的远程方法调用(Remote Method Invocation...
通过研究这些资源,开发者可以学习如何在自己的Web应用中集成DWR,实现类似聊天室的实时交互功能。 总的来说,DWR结合Comet技术为Web开发者提供了一种强大的工具,可以创建出具有实时更新功能的、用户友好的应用,...
### 基于Ajax技术的DWR框架的研究与应用 #### 概述 随着Web技术的不断发展,用户对于Web应用的交互性和响应速度有了更高的要求。传统的Web开发方式已难以满足这种需求,因此Ajax(Asynchronous JavaScript and XML...
DWR (Direct Web Remoting) 是一种开源的Java技术,它允许Web应用程序在客户端和服务器之间进行实时...通过深入研究这个“DWR技术文章精选”,开发者可以提升自己的技能,为Web应用开发带来更高效、更流畅的用户体验。
"基于DWR的AJAX技术研究与实现" 本文主要研究了基于DWR的AJAX技术的实现机制和应用。DWR是一个基于Java的开源框架,允许将服务器端的对象上的方法直接暴露给AJAX请求,从而可以直接调用服务器上的Servlet并获取处理...
DWR(Direct Web Remoting)是一种Java库,用于在Web应用程序中实现实时的JavaScript...通过深入研究这些材料,你不仅可以了解DWR的工作机制,还能学会如何在实际项目中有效地应用它,提升Web应用的交互性和用户体验。
"基于DWR的AJAX技术研究与实现" DWR(Direct Web Remoting)是一种基于Java的AJAX框架,它使得Java开发者可以轻松地在Web开发中使用AJAX技术。DWR的出现解决了Java开发者在使用AJAX技术时遇到的问题,使得Java...
DWR通过AJAX技术提供了一种简单的方法来更新网页的部分内容,而无需刷新整个页面,提高了用户体验。这个"TestDwr"压缩包文件提供的例子是一个简单的DWR应用示例,适合初学者理解和学习。 1. **DWR基本概念**: - ...
通过研究DWR源码,你可以了解到它如何处理HTTP请求、类型转换、安全验证等核心功能,这对于提升你在Web开发领域的技能,特别是对于理解和实现类似AJAX通信机制的应用非常有帮助。同时,这也是一个很好的学习服务器与...
在后台,`MessageService`通常会利用Spring的`JdbcTemplate`或`JPA`等持久化技术与数据库进行交互,执行SQL语句来完成CRUD操作。在这个例子中,可能有一个名为`Message`的实体类,对应数据库中的消息表。 5. **...
DWR(Direct Web Remoting)是一种JavaScript库,它允许Web应用程序进行实时的、异步的与服务器端Java...通过深入研究DWR的内部机制,你可以更好地优化代码,解决可能出现的问题,以及利用其特性来提升应用的用户体验。
Java DWR(Direct Web Remoting)框架是一种在Web应用程序中实现AJAX(Asynchronous JavaScript and XML)交互的技术。它允许JavaScript在客户端与服务器端的Java对象进行直接通信,从而实现页面的部分更新,提高...
DWR结合Ajax技术可以提供流畅的分页体验,用户无需等待整个页面加载,只需加载分页内容即可。 首先,了解DWR分页的基本概念。DWR的分页通常涉及以下几个关键组件: 1. **服务器端Java类**:这部分代码负责从数据库...
ExtJS和Direct Web Remoting(DWR)是两种在Web开发中常见的技术,它们结合使用可以构建出交互性极强的富客户端...通过研究这个例子,开发者可以更好地理解如何将这两项技术结合,从而提高Web应用的用户体验和效率。
- **异步通信**:DWR支持Ajax技术,允许浏览器与服务器进行异步交互,无需刷新整个页面。 - **类型安全**:DWR提供了类型安全的JavaScript接口,这意味着服务器端的方法在客户端调用时会自动转换为对应的...
"DWR与界面开发"可能是一篇教程或指南,介绍了如何使用DWR来增强Web界面的开发,特别是涉及到Ajax技术的应用。 **详细知识点:** 1. **DWR框架概述**:DWR允许Web应用程序在客户端和服务器之间交换数据和调用方法...
在提供的压缩包文件"**dwr_book**"中,可能包含了关于DWR的详细教程、示例代码或者案例研究,帮助你更深入地理解如何利用DWR实现补全查询功能。通过阅读和实践这些资料,你可以掌握如何在实际项目中应用这一技术,...
标题中的“关于dwr的视频”表明我们即将讨论的是DWR(Direct Web Remoting)在开发Web应用程序,特别是与AJAX交互方面的应用。...对于希望提升Web应用用户体验和性能的开发者来说,DWR是一个值得深入研究的工具。
2. **分析示例**:通过解压后的"DWR"文件,研究提供的示例代码,了解DWR如何被引入到项目中,并实现AJAX通信。 3. **实验环境**:在本地搭建一个试验环境,尝试运行示例,观察其工作过程。 4. **学习配置**:查看...