dwr进行页面推送简单实例

实现功能:sendMsg.jsp发送一个消息到后台,后台将消息推送到showMsg.jsp页面。

1、web.xml 配置,在web.xml里面添加如下内容:

<!-- 使用DWR进行页面消息推送  -->
	<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>

		<!-- 使用polling和comet的方式 -->
		<init-param>
			<param-name>pollAndCometEnabled</param-name>
			<param-value>true</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>

2、配置dwr.xml

<!DOCTYPE dwr PUBLIC
    "-//GetAhead Limited//DTD Direct Web Remoting 3.0//EN"
    "http://getahead.org/dwr/dwr30.dtd">

<dwr>
  <allow>
  <!-- 这里的javascript 值就是页面引用的第三个js文件的名称-->
    <create creator="new" javascript="SendMsg">
      <param name="class">iwco.dwrs.SendMsg</param>
    </create>
  </allow>
</dwr>

3、java类 SendMsg.java

package iwco.dwrs;

import java.util.Collection;

import org.directwebremoting.ScriptBuffer;
import org.directwebremoting.ScriptSession;
import org.directwebremoting.WebContext;
import org.directwebremoting.WebContextFactory;
import org.directwebremoting.proxy.dwr.Util;

public class SendMsg {
	 @SuppressWarnings("deprecation")
	    public void sendMsg(String msg){
	        //得到上下文
	        WebContext contex = WebContextFactory.get();  

	        //得到要推送到 的页面  dwr3为项目名称 , 一定要加上。
	        Collection<ScriptSession> sessions = contex.getScriptSessionsByPage("/dwrTest/showMsg.jsp");

	        //不知道该怎么解释这个 ,
	        Util util = new Util(sessions);

	        //下面是创建一个javascript脚本 , 相当于在页面脚本中添加了一句  show(msg);
	        ScriptBuffer sb = new ScriptBuffer();
	        sb.appendScript("show(");
	        sb.appendData(msg);
	        sb.appendScript(")");  

	        //推送
	        util.addScript(sb);
	    }
}

4、页面

sendMsg.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>sendMsg.jsp</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">

	<script type="text/javascript" src="/dwrTest/dwr/util.js"></script>
	<script type="text/javascript" src="/dwrTest/dwr/engine.js"></script>
	<script type="text/javascript" src="/dwrTest/dwr/interface/SendMsg.js"></script>
	<script type="text/javascript" src="/dwrTest/js/jquery.min.js"></script>
	<script type="text/javascript">
    $(function(){
        dwr.engine.setActiveReverseAjax(true);
        $("#but").click(function(){
            SendMsg.sendMsg($("#msg").val());
        });
    });
</script>
  </head>

  <body>
  	 <input type="text" id="msg"  />
    <input type="button" value="发送" id="but" />
  </body>
</html>

showMsg.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>showMsg</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">
	<script type="text/javascript" src="/dwrTest/dwr/util.js"></script>
	<script type="text/javascript" src="/dwrTest/dwr/engine.js"></script>
	<script type="text/javascript" src="/dwrTest/dwr/interface/SendMsg.js"></script>
	<script type="text/javascript" src="/dwrTest/js/jquery.min.js"></script>
	<script type="text/javascript">
    $(function(){
        //这句话千万不能少 ,表示允许使用推送技术
        dwr.engine.setActiveReverseAjax(true);
    });
    //这个函数是提供给后台推送的时候  调用的
    function show(msg){
        $("#message").text(msg);
    }
</script>
  </head>

  <body>
  <div id="message" style="width: 200px;height: 200px;border: 1px solid red ; text-align: center; padding: 5px;"></div>
  </body>
</html>
时间: 2024-11-08 15:11:28

dwr进行页面推送简单实例的相关文章

dwr进行消息推送示例

<?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="

极光推送使用实例(二) Android客户端

上一篇简单介绍了极光推送在Java服务端的实现,如果感兴趣的可以看一下极光推送使用实例(一)JAVA服务端.这篇文章介绍下极光推送在Android客户端的实现. JPush Android SDK 是作为 Android Serivice 长期运行在后台的,从而创建并保持长连接,保持永远在线的能力.JPush Android SDK 由于使用自定义协议,协议体做得极致地小,流量消耗非常地小.电量方面,JPush Android SDK 经过持续地优化,尽可能减少不必要的代码执行:并且,长期的版本

WebSocket 的一些简单页面推送使用

因为做通信项目的时候,需要实时获取每个分机的当前状态,发现websocket还不错,知识对浏览器的要求比较高, 针对特定用户推送消息,网上有一些 public class GetHttpSessionConfigurator  extends ServerEndpointConfig.Configurator{ @Override public void modifyHandshake(ServerEndpointConfig config,HandshakeRequest request,Ha

iOS关于UITabView和UIAlertController,UIAlertAction以及UINavigation,值修改的传递页面推送

关于UITabView和UIAlertController,UIAlertAction以及UINavigation,值修改的传递 集合嵌套集合的操作 声明 两个必须的的代理 实现部分代码 - (void)viewDidLoad { [super viewDidLoad]; // 创建一个TabView self.tabv = [[UITableView alloc] initWithFrame:self.view.frame style:UITableViewStyleGrouped]; sel

极光推送 使用实例 (一)服务端

最近一直在做后台开发,但心里还是总惦记着Android,感觉还是Android有意思.正好项目中要用到极光推送,今天抽空来记录下这两天的研究成果. 我们知道iOS有自己的推送服务,但很遗憾Android没有原生的推送服务,现在有很多第三方的推送服务,比如个推.极光.亚马逊.百度云.聚能等.今天我们就来研究下极光推送的后台服务器如何实现. 关键点: 1.首先最好是把极光官网Java后台服务器的demo下载下来,里面有我们需要的jar包,以及example. 2.极光推送的关键jpushClient

rsync 推送简单配置

安装xinetd , 修改rsync配置 a. yum install xinetd b. vi /etc/xinetd.d/rsync service rsync {         disable = no  # 将 yes 修改为 no         flags           = IPv6         socket_type     = stream         wait            = no         user            = root     

Ionic JPush极光推送 插件实例

1.需要去这里注册https://www.jiguang.cn 注册成功获取AppKey 备注填写应用包名规范点,在项目还要用那 2.创建ionic 项目 指定你注册时候的包名(假如:com.ionicframework.ltapp) ionic start  -i com.ionicframework.ltapp ltapp blank 3.添加JPush 插件 进入 项目目录下 cd  ltapp git clone https://github.com/jpush/jpush-phoneg

本地推送 简单代码演示

1 第一步:创建本地推送 2 // 创建一个本地推送 3 UILocalNotification *notification = [[[UILocalNotification alloc] init] autorelease]; 4 //设置10秒之后 5 NSDate *pushDate = [NSDate dateWithTimeIntervalSinceNow:10]; 6 if (notification != nil) { 7     // 设置推送时间 8     notificat

友盟推送简单调用

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions 设置参数