dwr消息推送

2024-06-02 18:58
文章标签 推送 消息 dwr

本文主要是介绍dwr消息推送,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


在做jsp系统时,有时候会有群发消息或及时推送消息的功能,如果用ajax请求,设置settimeout不断的请求服务器会给浏览器造成很大的压力,这时就可以用dwr技术进行消息推送。dwr根据自身的机制及时推送消息,不需要自己请求服务器就可以接受到消息。可以实现网页间的发送消息,以及服务器直接像客户端发送消息。 比如实现在线交流、股市动态刷新数据等。

下面提供一个简单的案例,说明一下配置。

实现一个网页向另一个网页发送消息:

结果如下:点击发送,另一个网页显示信息


具体代码:

web.xml 中添加如下代码:

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="3.0"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_3_0.xsd"><servlet>  <servlet-name> dwr-invoker </servlet-name>  <servlet-class> uk.ltd.getahead.dwr.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><init-param><param-name> allowScriptTagRemoting</param-name ><param-value> true</param-value ></init-param><init-param><param-name> activeReverseAjaxEnabled</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></web-app>

在web.xml同级目录添加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>  <create creator="new" javascript= "messagePush"> <param name="class" >sugar.dwr.MessagePush</param> </create></allow>  
</dwr>

java代码:包名和dwr.xml中的配置一致

package sugar.dwr;import java.util.Collection;import org.directwebremoting.Browser;
import org.directwebremoting.ScriptBuffer;
import org.directwebremoting.ScriptSession;public class MessagePush {public void send(final String content){Runnable run = new Runnable(){private ScriptBuffer script = new ScriptBuffer();public void run() {System.out.println(content);//设置要调用的 js及参数script.appendCall("show" , content);//得到所有ScriptSessionCollection<ScriptSession> sessions = Browser.getTargetSessions();//遍历每一个ScriptSessionfor (ScriptSession scriptSession : sessions){scriptSession.addScript( script);}}};//执行推送Browser. withAllSessions(run);}}

发送页面:js方法名和xml配置中的以及java方法名一致

<%@ page language= "java" import ="java.util.*" pageEncoding="UTF-8" %>
<%String a = "a"; %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head ><title >DWR</title><script type= "text/javascript" src ="js/jquery.min.js"></script><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/messagePush.js" ></script></head ><body ><table border="0" ><tr><td><input id ="content" type="text"/></td><td><input id ="send" type="button" value= "send"/></td ></tr></table><script type="text/javascript" >$( "#send").click(function(){<%if("".equals(a)){%>alert("您不具有发送消息权限");<%}else{%>var content = $("#content" ).val();messagePush.send(content);<%}%>});</script></body >
</html>

接受页面:

<%@ page language= "java" import ="java.util.*" pageEncoding="UTF-8" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head ><title >dwr接收</title ><script src="js/jquery.min.js" ></script><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/messagePush.js" ></script><script type="text/javascript" src="js/ymPrompt.js"></script><link rel="stylesheet" type="text/css" href="css/ymPrompt.css" /></head ><body >dwr接收<br /><div id="content" style=" width: 200px ;height: 30px;border : 1px solid ; text-align: center ; padding: 5px;"></div><script type="text/javascript" >//这个方法用来启动该页面的ReverseAjax功能dwr.engine.setActiveReverseAjax( true);//设置在页面关闭时,通知服务端销毁会话dwr.engine.setNotifyServerOnPageUnload( true);//这个函数是提供给后台推送的时候 调用的function show(content){ //alert(content);$( "#content" ).text(content);// ymPrompt.alert('提示',null,null,'确认要提交吗?',handler);}</script></body >
</html>

引入jar包:

客户端网页 中的js文件只需引入jquery的,其他的不用管,都在dwr里面封装好了。

jar包和js下载:

http://download.csdn.net/detail/u011250851/7888111


有什么问题可以直接回复我。



这篇关于dwr消息推送的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Boot整合消息队列RabbitMQ的实现示例

《SpringBoot整合消息队列RabbitMQ的实现示例》本文主要介绍了SpringBoot整合消息队列RabbitMQ的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目录RabbitMQ 简介与安装1. RabbitMQ 简介2. RabbitMQ 安装Spring

springboot rocketmq配置生产者和消息者的步骤

《springbootrocketmq配置生产者和消息者的步骤》本文介绍了如何在SpringBoot中集成RocketMQ,包括添加依赖、配置application.yml、创建生产者和消费者,并展... 目录1. 添加依赖2. 配置application.yml3. 创建生产者4. 创建消费者5. 使用在

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

解读Redis秒杀优化方案(阻塞队列+基于Stream流的消息队列)

《解读Redis秒杀优化方案(阻塞队列+基于Stream流的消息队列)》该文章介绍了使用Redis的阻塞队列和Stream流的消息队列来优化秒杀系统的方案,通过将秒杀流程拆分为两条流水线,使用Redi... 目录Redis秒杀优化方案(阻塞队列+Stream流的消息队列)什么是消息队列?消费者组的工作方式每

使用C/C++调用libcurl调试消息的方式

《使用C/C++调用libcurl调试消息的方式》在使用C/C++调用libcurl进行HTTP请求时,有时我们需要查看请求的/应答消息的内容(包括请求头和请求体)以方便调试,libcurl提供了多种... 目录1. libcurl 调试工具简介2. 输出请求消息使用 CURLOPT_VERBOSE使用 C

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

SpringBoot 自定义消息转换器使用详解

《SpringBoot自定义消息转换器使用详解》本文详细介绍了SpringBoot消息转换器的知识,并通过案例操作演示了如何进行自定义消息转换器的定制开发和使用,感兴趣的朋友一起看看吧... 目录一、前言二、SpringBoot 内容协商介绍2.1 什么是内容协商2.2 内容协商机制深入理解2.2.1 内容

ActiveMQ—消息特性(延迟和定时消息投递)

ActiveMQ消息特性:延迟和定时消息投递(Delay and Schedule Message Delivery) 转自:http://blog.csdn.net/kimmking/article/details/8443872 有时候我们不希望消息马上被broker投递出去,而是想要消息60秒以后发给消费者,或者我们想让消息没隔一定时间投递一次,一共投递指定的次数。。。 类似

Java消息队列:RabbitMQ与Kafka的集成与应用

Java消息队列:RabbitMQ与Kafka的集成与应用 大家好,我是微赚淘客返利系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿! 在现代的分布式系统中,消息队列是实现系统间通信、解耦和提高可扩展性的重要组件。RabbitMQ和Kafka是两个广泛使用的消息队列系统,它们各有特点和优势。本文将介绍如何在Java应用中集成RabbitMQ和Kafka,并展示它们的应用场景。 消息队

Kafka 分布式消息系统详细介绍

Kafka 分布式消息系统 一、Kafka 概述1.1 Kafka 定义1.2 Kafka 设计目标1.3 Kafka 特点 二、Kafka 架构设计2.1 基本架构2.2 Topic 和 Partition2.3 消费者和消费者组2.4 Replica 副本 三、Kafka 分布式集群搭建3.1 下载解压3.1.1 上传解压 3.2 修改 Kafka 配置文件3.2.1 修改zookeep