- 浏览: 138066 次
- 性别:
- 来自: 火星
文章分类
最新评论
-
yaoneng:
谢谢~~不错~~
Eclipse格式化不换行 -
fys124974704:
没想过中文的条形码!
项目使用条形码 -
yangpanwww:
你好! 内容好像不支持中文。。有什么解决方案不
项目使用条形码 -
fys124974704:
Stone_eye 写道fys124974704 写道Ston ...
flowplayer学习 -
Stone_eye:
fys124974704 写道Stone_eye 写道哥们,想 ...
flowplayer学习
开始我曾经用PHP做过一个聊天室,但是需要用JS不停的刷新去获取新的信息,这样让我感觉增加浏览器和服务器的负担,因为需要时时去请求!
当我看到DWR2也可以实现推技术之后,我突然想尝试一下!
首先当官方上下载一个dwr的jar文件和commons-logging-1.1.1.jar
先从配置文件入手
web.xml
<?xml version="1.0" encoding="UTF-8"?> <web-app id="WebApp_ID" version="2.4" 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"> <!-- 以设置下格式固定,可复制使用 --> <display-name>ajaxDWR</display-name> <servlet> <servlet-name>dwr-invoker</servlet-name> <!-- <servlet-class>uk.ltd.getahead.dwr.DWRServlet</servlet-class> --> <servlet-class> org.directwebremoting.servlet.DwrServlet </servlet-class> <init-param> <description>实现调试,在debug请设置为false</description> <param-name>debug</param-name> <param-value>true</param-value> </init-param> <init-param> <description>使用服务器推技术(反转AJAX)</description> <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>100</param-value> </init-param> <load-on-startup>4</load-on-startup> </servlet> <servlet-mapping> <servlet-name>dwr-invoker</servlet-name> <url-pattern>/dwr/*</url-pattern> </servlet-mapping> </web-app>
dwr.xml
<?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.dwr.chat.Chat" /> </create> </allow> </dwr>
编写好配置文件之后,开始编写页面,我们可以选择html或者jsp都可以
index3.html
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>index3.html</title> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="this is my page"> <meta http-equiv="content-type" content="text/html; charset=UTF-8"> <script type='text/javascript' src='dwr/util.js'></script> <script type='text/javascript' src='dwr/engine.js'></script> <script type='text/javascript' src='dwr/interface/Chat.js'></script> <!--<link rel="stylesheet" type="text/css" href="./styles.css">--> </head> <body> <center> <table width="600px" border="1"> <tr> <td colspan="3" align="center"> XXXXXX Chat </td> <td> User List </td> </tr> <tr> <td colspan="3" style="height: 300px"> <textarea rows="20" cols="60" readonly id="showmessage" name="showmessage"></textarea> </td> <td style="height: 300px" valign="top"> <div id="userlist" style="height:310px;overflow : scroll;"></div> </td> </tr> <tr> <td colspan="3" align="center"> <span id="say_name" ></span> <textarea rows="3" cols="50" id="say_message" name="say_message"></textarea><input type="button" value="say" id="say" onclick="sayMessage()"/> </td> <td> 先录入你的昵称<br/> <input type="text" style="width: 125px" name="name" id="name" /> <input type="button" value="确定" onclick="register()" /> </td> </tr> </table> </center> </body> <script type="text/javascript"> dwr.engine.setActiveReverseAjax(true); // 激活反转 重要 init(); function init(){ document.getElementById('say_message').disabled = true; document.getElementById('say').disabled = true; } function sayMessage(){ var message_content = DWRUtil.getValue('say_message'); var message_head = document.getElementById('say_name').innerHTML; Chat.sayMessage(message_head+message_content); document.getElementById('say_message').value = ''; } function register() { var name = DWRUtil.getValue("name"); Chat.addUser(name,callback); } function callback(str) { if(str != ''){ alert(str); }else{ document.getElementById('say_name').innerHTML = DWRUtil.getValue("name") + " 说:"; document.getElementById('say_message').disabled = false; document.getElementById('say').disabled = false; } } </script> </html>
这个页面比较简陋,建议js写在下方,否则firefox会报错
Chat.java
package com.dwr.chat; import java.util.ArrayList; import java.util.Collection; import javax.servlet.ServletContext; import javax.servlet.http.HttpServletRequest; import org.directwebremoting.ServerContext; import org.directwebremoting.ServerContextFactory; import org.directwebremoting.proxy.dwr.Util; public class Chat { static ArrayList<String> name_list = new ArrayList<String>(); static StringBuffer show_message = new StringBuffer(); public String addUser(String name,HttpServletRequest request) { System.out.println("list.size() = "+name_list.size()); for (String s : name_list) { if (name == null || name.trim().equals(s)) { return "用户名已存在"; } } name_list.add(name.trim()); ServletContext sc = request.getSession().getServletContext(); ServerContext sctx = ServerContextFactory.get(sc); Collection sessions = sctx.getScriptSessionsByPage("/dwr2Demo/index3.html"); Util util = new Util(sessions); show_message.append("\n欢迎"+name+"来到 XXX Chat"); trimMessage(); util.setValue("showmessage", show_message.toString()); printUserList(util); return ""; } public void sayMessage(String message,HttpServletRequest request){ ServletContext sc = request.getSession().getServletContext(); ServerContext sctx = ServerContextFactory.get(sc); Collection sessions = sctx.getScriptSessionsByPage("/dwr2Demo/index3.html"); Util util = new Util(sessions); show_message.append("\n"+message); trimMessage(); util.setValue("showmessage", show_message.toString()); printUserList(util); } public void trimMessage(){ if(show_message.length() > 2000){ show_message.delete(0, ((show_message.length() - 2000)*2+2)); } } public void printUserList(Util util){ StringBuffer userlist = new StringBuffer(); userlist.append("<table>"); for(String s : name_list){ userlist.append("<tr><td><font color='blue'>"+s+"</font></td></tr>"); } userlist.append("</table>"); util.setValue("userlist", userlist.toString()); } }
编写好这个之后,可以运行一下。
经过测试,发现几个问题 浏览器我现在测试了三种发现三种都有自己的特性
IE :比较正常,有时候会慢一些
firefox :每次刷新访问的时候服务器会出现一个异常
google浏览器:在刷新的时候会无限等待,一直到接收到信息
发表评论
-
某网站系统升级遇到的问题
2011-01-07 10:08 990某网站前端系统升级,开发机器使用win2003,浏览器测试IE ... -
Linux+Lucene+Tomcat+OpenEjb发布细节
2011-01-06 18:04 55细节1:首先在linux系统上先查看ulimit -a ... -
ejb定时器
2010-12-29 16:43 110如何在EJB容器做一个定时器,分四个步骤: 1 配置运行环境 ... -
IO流的笔记(一)
2010-11-01 11:23 69import java.io.FileInputStre ... -
项目使用条形码
2009-06-15 10:59 2121首先要去http://barcode4j.so ... -
注意Java的误区
2009-04-28 17:15 839import java.util.ArrayList; /* ... -
JPA (一)
2009-04-20 11:05 647JPA 全称 Java Persistence A ... -
Properties里面的一些系统值
2009-03-25 10:03 714当我们需要求出一些系统参数的时候,需要使用到Prope ... -
log4j 简单使用
2009-01-12 16:26 1317使用Log4j 感觉好像就是学怎么写它的配置文件 呵呵!! ... -
log4j.properties 配置
2009-01-12 16:22 1017og4j.properties 使用一.参数意义说明输出级别的 ... -
Aspectj 入门(一)
2008-12-30 21:14 3762由于Spring的配置过多,个人不喜欢!但是又想使 ... -
日期处理笔记
2008-12-16 14:21 957获取上个月 java.text.SimpleDateForm ... -
struts2-入门实例
2008-11-25 08:35 938struts2 传说中很优秀的web框架,融合了webw ... -
JSF入门例子
2008-11-21 12:00 7738首先去 http://java.sun.com/javaee/ ... -
J2ME学习选择
2008-11-07 08:28 932J2ME学习起来感觉还是比较多方向的,基于手机有很多系统,但是 ... -
一个MIDlet的入门例子
2008-11-05 10:02 906import javax.microedition.lcdu ... -
精简之美
2008-10-30 09:18 837有一条阶乘的问题,就是怎么去写才能让代码最少,最精简!我想了很 ... -
quartz入门一
2008-10-14 14:00 1693quartz是一个好东西!一直想使用它做一些事情,就是没 ... -
logic-iterator用法
2008-09-22 14:26 1612<%@ page language="java ... -
java反射---我之见解
2008-08-25 11:47 1500最近在做一个项目,开始就没打算使用反射,但是做着做着, ...
相关推荐
在“DWR3实现服务器端向客户端精确推送消息”这一主题中,我们将深入探讨如何利用DWR3进行服务器到客户端的消息推送,以及这种技术的优势和应用。 首先,理解DWR3的工作原理是至关重要的。DWR3通过建立一个安全的...
在这个"**dwr实现的服务器推demo**"中,我们看到一个实例,展示了如何利用DWR的技术来实现实时的、无需刷新的服务器推送功能。 服务器推是一种技术,它允许服务器主动地将数据发送到客户端,而不需要客户端(通常是...
"dwr实现服务器推技术,兼容低版本IE"这一主题,表明我们将讨论如何利用DWR实现在旧版Internet Explorer上的服务器推送功能。 1. **DWR基础原理** DWR的核心在于创建一个JavaScript对象,该对象可以直接调用服务器...
Java+dwr框架实现聊天室是使用Java语言和dwr框架实现的服务器推技术,实现了实时通信的聊天室功能。下面将详细介绍该技术的实现过程和相关知识点。 一、dwr 框架简介 dwr(Direct Web Remoting)是一种基于Ajax...
DWR使用一种称为Reverse Ajax或Comet的技术来实现服务器推送。它创建了一个持久化的HTTP连接,使得服务器可以在准备好新数据时立即发送,而不需要等待客户端的请求。DWR提供了一种简单的方式来注册JavaScript函数,...
总结来说,DWR推技术是实现服务器主动向客户端推送数据的一种高效方式,尤其适用于需要实时数据更新的应用,如股票实时显示。通过反转Ajax,DWR简化了开发流程,提高了用户体验,是现代Web开发中的一个重要工具。
- **Remoting**:远程方法调用,DWR的核心特性,它使JavaScript可以直接调用服务器上的Java方法,实现了浏览器与服务器之间的双向通信。 - **Reverse Ajax**:DWR利用了这个概念,即服务器可以主动向客户端发送数据...
本文将详细介绍如何实现DWR的服务器推送功能。 一、DWR简介 DWR的核心功能是通过AJAX技术创建了一个JavaScript到Java的桥梁,使得开发者可以像操作本地对象一样操作远程服务器上的对象。它支持自动类型转换、错误...
总的来说,DWR推送技术通过Comet实现了高效的服务器到客户端的数据推送,简化了实时Web应用的开发。结合提供的源码示例"j-jetty-dwr-comet-src",开发者可以深入理解DWR的工作原理,并学习如何在实际项目中应用这项...
**DWR(Direct Web Remoting)技术是一种在Web应用程序中实现AJAX(Asynchronous JavaScript and XML)通信的方法,它允许JavaScript直接调用Java方法,从而实现在不刷新整个页面的情况下更新部分网页内容。...
在本项目"jsp DWR框架推模式实现的聊天室"中,我们将探讨如何利用DWR的推送(Push)模式来构建一个实时的在线聊天应用。** 首先,我们需要了解DWR的基本工作原理。DWR通过在浏览器和服务器之间建立一个持久连接,...
标题中的“用DWR comet+Spring实现服务器推送的例子--网页聊天室”涉及到的是Web开发中的实时通信技术。DWR(Direct Web Remoting)是一个开源Java库,它允许JavaScript在浏览器和服务器之间进行直接的、安全的远程...
【标题】: 使用DWR的Comet推送技术创建多人聊天室 【描述】: 本文主要探讨如何通过Spring与Direct Web Remoting (DWR)框架的整合,利用Comet技术来构建一个无需刷新页面的多人在线聊天室。Comet是一种实现服务器到...
本实例将通过一个点对点聊天功能的实现,深入探讨DWR的推技术。 ### DWR基础 1. **反向Ajax(Reverse Ajax)**:DWR的核心功能之一是实现反向Ajax,即服务器可以主动向客户端推送数据,而不仅仅是响应客户端的请求...
这种技术允许服务器主动地向客户端推送数据,而不仅仅是响应客户端的请求,这在构建实时更新的应用,如聊天室、股票报价或在线游戏等场景中非常有用。 在描述中提到的"DWR服务器推技术整合Struts2",意味着我们将...
- **反向Ajax(Reverse Ajax)**:DWR的核心是反向Ajax技术,它使服务器能够主动推送数据到客户端,而不仅仅是响应客户端的请求。 - **CORS(Cross-Origin Resource Sharing)**:DWR支持跨域资源共享,允许不同源...
DWR是一个用于改善web页面与Java类交互的远程服务器端Ajax开源框架,可以帮助开发人员开发包含AJAX技术的网站。它可以允许在浏览器里的代码使用运行在WEB服务器上的JAVA函数,就像它就在浏览器里一样。
总结来说,DWR服务器推送技术为构建实时交互的Web应用提供了强大的工具,使得像WebQQ这样的聊天应用得以实现。通过理解其工作原理和实现步骤,开发者可以运用这项技术来提升Web应用的用户体验。在实际开发中,还需...
本示例将深入探讨如何使用DWR与Spring框架集成,实现服务器主动推送功能。 首先,我们需要理解DWR的核心概念: 1. **DWR Engine**: 是DWR的核心组件,它处理客户端和服务器之间的通信,包括JavaScript到Java的调用...