`
frank59
  • 浏览: 9844 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

用DWR comet+Spring实现服务器推送的例子--网页聊天室

阅读更多

最近网上看的代码 敲下来试试 行得通 于是拿到这里和大家分享下。

首先 下载DWR的JAR包 下载地址http://directwebremoting.org/dwr/downloads/index.html

接下来 在web工程中加入相应的jar包,因为用到了spring的消息驱动机制 如下

接下来是文件结构

---------------------------------------

 

现在开始写代码了

Message.java                    单位信息的承载类

package entity;
import java.util.Date;
/**
 * 作为信息传递的基础类
 * @author WANGHENG
 *
 */
public class Message {
	private int id;
	private String msg;
	private Date time;
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public String getMsg() {
		return msg;
	}
	public void setMsg(String msg) {
		this.msg = msg;
	}
	public Date getTime() {
		return time;
	}
	public void setTime(Date time) {
		this.time = time;
	}
}
 

ChatMessageEvent.java

package chat;
import org.springframework.context.ApplicationEvent;
/**
 * 自定义事件类
 * @author WANGHENG
 *
 */
public class ChatMessageEvent extends ApplicationEvent{

	public ChatMessageEvent(Object source) {
		super(source);
	}
	private static final long serialVersionUID = -6626763488290315190L;
}

 

ChatMessageClient.java

package chat;
import java.util.Collection;
import java.util.Date;
import javax.servlet.ServletContext;
import org.directwebremoting.ScriptBuffer;
import org.directwebremoting.ScriptSession;
import org.directwebremoting.ServerContext;
import org.directwebremoting.ServerContextFactory;
import org.springframework.context.ApplicationEvent;
import org.springframework.context.ApplicationListener;
import org.springframework.web.context.ServletContextAware;

import entity.Message;
/**
 * MessageEvent事件的监听类
 * 需要spring的支持 利用spring的消息驱动机制
 * @author WANGHENG
 *
 */
@SuppressWarnings("unchecked")
public class ChatMessageClient implements ApplicationListener,
		ServletContextAware {
	private ServletContext ctx;

	@SuppressWarnings("deprecation")
	public void onApplicationEvent(ApplicationEvent event) {
		// 如果事件类型是ChatMessageEvent就执行下面操作
		if (event instanceof ChatMessageEvent) {
			Message msg = (Message) event.getSource();
			ServerContext context = ServerContextFactory.get();
			// 获得客户端所有chat页面script session连接数
			Collection<ScriptSession> sessions = context
					.getScriptSessionsByPage(ctx.getContextPath() + "/chat.jsp");
			for (ScriptSession session : sessions) {
				ScriptBuffer sb = new ScriptBuffer();
				Date time = msg.getTime();
				String s = time.getYear() + "-" + (time.getMonth() + 1) + "-"
						+ time.getDate() + " " + time.getHours() + ":"
						+ time.getMinutes() + ":" + time.getSeconds();
				System.out.println(s);/////////////////s
				// 执行setMessage方法
				sb.appendScript("showMessage({msg: '").appendScript(
						msg.getMsg()).appendScript("', time: '")
						.appendScript(s).appendScript("'})");
				System.out.println(sb.toString());/////////////////sb
				//执行客户端script session方法,相当于浏览器执行JavaScript代码                   
				//上面就会执行客户端浏览器中的showMessage方法,并且传递一个对象过去  
				session.addScript(sb);
			}
		}
	}
	public void setServletContext(ServletContext arg0) {
		this.ctx = arg0;
	}
}

 

applicationContext-beans.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop"
	xmlns:tx="http://www.springframework.org/schema/tx" xmlns:util="http://www.springframework.org/schema/util"
	xmlns:context="http://www.springframework.org/schema/context"
	xsi:schemaLocation="http://www.springframework.org/schema/beans 
	http://www.springframework.org/schema/beans/spring-beans-3.0.xsd 
	http://www.springframework.org/schema/aop       
	http://www.springframework.org/schema/aop/spring-aop-3.0.xsd      
	http://www.springframework.org/schema/tx       
	http://www.springframework.org/schema/tx/spring-tx-3.0.xsd      
	http://www.springframework.org/schema/util       
	http://www.springframework.org/schema/util/spring-util-3.0.xsd      
	http://www.springframework.org/schema/context       
	http://www.springframework.org/schema/context/spring-context-3.0.xsd">
	<bean id="chatService" class="chat.ChatService"/> 
	<bean id="chatMessageClient" class="chat.ChatMessageClient"/>
</beans>

 

dwr.xml

<?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>
		<convert match="entity.Message" converter="bean">
			<param name="include" value="msg,time" />
		</convert>
		<create creator="spring" javascript="ChatService">
			<param name="beanName" value="chatService" />
		</create>
	</allow>
</dwr>

 

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
	http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
	<!-- 加载Spring容器配置 -->
	<listener>
		<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
	</listener>
	<!-- 设置Spring容器加载配置文件路径 -->
	<context-param>
		<param-name>contextConfigLocation</param-name>
		<param-value>classpath*:applicationContext-*.xml</param-value>
	</context-param>
	<listener>
		<listener-class>org.directwebremoting.servlet.DwrListener</listener-class>
	</listener>
	<servlet>
		<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>
		<!-- dwr的comet控制 -->
		<init-param>
			<param-name>pollAndCometEnabled</param-name>
			<param-value>true</param-value>
		</init-param>
	</servlet>
	<servlet-mapping>
		<servlet-name>dwr-invoker</servlet-name>
		<url-pattern>/dwr/*</url-pattern>
	</servlet-mapping>
	<welcome-file-list>
		<welcome-file>index.jsp</welcome-file>
	</welcome-file-list>
</web-app>

 

ChatService.js文件为空白文件

 

chat.jsp

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
	<head>
		<base href="<%=basePath%>">

		<title>My JSP 'chat.jsp' starting page</title>

		<meta http-equiv="pragma" content="no-cache">
		<meta http-equiv="cache-control" content="no-cache">
		<meta http-equiv="expires" content="0">
		<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
		<meta http-equiv="description" content="This is my page">
		<!--
	<link rel="stylesheet" type="text/css" href="styles.css">
	-->
		<script type="text/javascript"
			src="${pageContext.request.contextPath }/dwr/engine.js"></script>
		<script type="text/javascript"
			src="${pageContext.request.contextPath }/dwr/util.js"></script>
		<script type="text/javascript"
			src="${pageContext.request.contextPath }/dwr/interface/ChatService.js"></script>
		<script type="text/javascript">         
			function send() {              
				var time = new Date();              
				var content = dwr.util.getValue("content");              
				var name = dwr.util.getValue("userName");              
				var info = encodeURI(encodeURI(name + " say:\n" + content));              
				var msg = {"msg": info, "time": time};              
				dwr.util.setValue("content", "");              
				if (!!content) {                  
					ChatService.sendMessage(msg);              
				} else {                  
					alert("发送的内容不能为空!");              
				}          
			}             
			function showMessage(data) {              
				var message = decodeURI(decodeURI(data.msg));              
				var text = dwr.util.getValue("info");              
				if (!!text) {                    
					dwr.util.setValue("info", text + "\n" + data.time + "  " + message);              
				} else {                  
					dwr.util.setValue("info", data.time + "  " + message);              
				}          
			}      
		</script>
	</head>

	<body onload="dwr.engine.setActiveReverseAjax(true);">
		<textarea rows="20" cols="60" id="info" readonly="readonly"></textarea>
		<hr />
		昵称:<input type="text" id="userName" />
		<br />
		消息:<textarea rows="5" cols="30" id="content"></textarea>
		<input type="button" value=" Send " onclick="send()" style="height: 85px; width: 85px;" />
	</body>
</html>
 

实现效果

 

这段代码是从http://developer.51cto.com/art/201106/267962.htm  照搬下来的。

其中engine.jsutil.js 在附件中

  • dwr.zip (22.2 KB)
  • 下载次数: 89
分享到:
评论

相关推荐

    使用dwr+spring实现消息推送

    在IT行业中,消息推送是一项重要的技术,它使得服务器能够实时地向客户端发送数据,而无需客户端不断地轮询请求。在本教程中,我们将探讨如何利用Direct Web Remoting (DWR) 和Spring框架来实现这样的功能。 DWR是...

    疯狂Ajax讲义:Prototype/jQuery+DWR+Spring+Hibernate整合开发(part01)

    《疯狂Ajax讲义:Prototype/jQuery+DWR+Spring+Hibernate整合开发》绝大部分章节后都提供了相应的编程习题,供开发者巩固所学,将理论融入实际开发之用。关于这些编程习题的解题思路和参考答案可登录www.crazyit.org...

    dwr3.0+spring2.5实现Comet消息推送DEMO

    实现Comet消息推送功能,根据登陆人定向推送,解决刷新页面原有ScriptSession不能及时销毁的问题,DEMO比较简陋,请先进入login.jsp页面登陆。根据登陆名称判断推送目标,可登陆多个用户进行测试。

    DWR+JAVA进行web消息推送dwr-comet.zip

    在本文中,我们将深入探讨如何使用DWR(Direct Web Remoting)与Java技术结合实现Web消息推送功能。DWR是一种JavaScript库,它允许在浏览器和服务器之间进行实时、双向通信,为Web应用提供了类似AJAX的功能,但更加...

    dwr+spring实现后台向前台推送实例

    本实例是在一些网络资料的基础上整合出来的一个:以后台向前台页面推送消息的一个完整实例工程,采用了spring、dwr反转,实现的是后台向前台不断推送消息,并管理相关用户退出;可以用在如定时任务的桌面消息提醒之...

    DWR+Struts+spring+hibernate的订货系统

    DWR+Struts+spring+hibernate的订货系统,自己添加的dwr功能

    Spring整合DWR comet 实现无刷新 多人聊天室代码整理

    Spring整合DWR(Direct Web Remoting)和Comet技术,是一种高效的实现Web应用程序实时通信的解决方案,特别适用于创建如多人聊天室这样的实时交互应用。在这个项目中,Spring作为后端框架,负责业务逻辑处理和控制...

    dwr spring服务器主动推送示例代码

    本示例将深入探讨如何使用DWR与Spring框架集成,实现服务器主动推送功能。 首先,我们需要理解DWR的核心概念: 1. **DWR Engine**: 是DWR的核心组件,它处理客户端和服务器之间的通信,包括JavaScript到Java的调用...

    DWR3实现服务器端向客户端精确推送消息

    在“DWR3实现服务器端向客户端精确推送消息”这一主题中,我们将深入探讨如何利用DWR3进行服务器到客户端的消息推送,以及这种技术的优势和应用。 首先,理解DWR3的工作原理是至关重要的。DWR3通过建立一个安全的...

    DWR+spring数据推送

    在**Spring框架**中集成DWR,可以实现高效的数据推送功能。Spring作为一个强大的企业级应用框架,提供了丰富的服务和组件,包括依赖注入、AOP(面向切面编程)、事务管理等,这些都能与DWR无缝结合,提高应用的可...

    用DWR的comet推,实现多人聊天室

    【标题】: 使用DWR的Comet推送技术创建多人聊天室 【描述】: 本文主要探讨如何通过Spring与Direct Web Remoting (DWR)框架的整合,利用Comet技术来构建一个无需刷新页面的多人在线聊天室。Comet是一种实现服务器到...

    dwr+spring+hibernate模板.zip

    《DWR+Spring+Hibernate整合应用详解》 在IT领域,DWR(Direct Web Remoting)、Spring和Hibernate是三个至关重要的技术组件,它们分别在Web应用程序的远程调用、依赖注入和对象关系映射方面发挥着核心作用。将这三...

    DWR+extjs+spring+hibernate

    在IT行业中,DWR(Direct Web Remoting)是一种JavaScript库,它允许Web应用程序与服务器端的Java代码进行实时交互,从而实现动态、富客户端的Web应用。EXTJS则是一个强大的JavaScript UI框架,提供了丰富的组件和...

    dwr+spring+hibernate的经典例子

    DWR使得动态更新网页成为可能,用户无需刷新整个页面就能获取服务器的新数据。这种Ajax(Asynchronous JavaScript and XML)技术的应用,极大地提升了用户体验,因为它减少了页面加载时间并提高了响应速度。在DWR中...

    DWR+hibernate+spring未完成例子

    【标题】:“DWR+Hibernate+Spring未完成例子”揭示了这个压缩包中包含的是一个未完成的示例项目,该示例项目整合了Direct Web Remoting (DWR)、Hibernate ORM框架和Spring框架。这三者都是Java Web开发中的重要组件...

    Spring+DWR+ibatis+jQuery+easyUI的框架例子

    Spring+DWR+ibatis+jQuery+easyUI的框架例子. 完全开放源代码,免费学习与使用。 可以完成基本的后台主界面,报表查询,数据查询,增加,修改等功能。 如果你要做一些报表,后台功能利用这个a框架就可以很方便实现。

    DWR推送技术大全 dwr推送聊天实例

    总的来说,DWR推送技术通过Comet实现了高效的服务器到客户端的数据推送,简化了实时Web应用的开发。结合提供的源码示例"j-jetty-dwr-comet-src",开发者可以深入理解DWR的工作原理,并学习如何在实际项目中应用这项...

    dwr+springJdbc例子

    总结来说,"dwr+springJdbc例子"展示了如何利用DWR实现实时的前后端交互,Spring提供依赖注入和数据访问抽象,而JDBC则负责与数据库的底层通信。这样的组合使得开发高效、灵活且易于维护的Web应用成为可能。理解并...

    Ext+dwr+spring做的例子程序

    【标题】"Ext+dwr+spring做的例子程序"是一个整合了三个关键技术的示例应用,主要展示了如何在Java Web开发中结合使用EXTJS(Ext)前端框架、Direct Web Remoting (DWR) 和Spring框架。这三个技术在现代企业级应用...

Global site tag (gtag.js) - Google Analytics