基于Pushlet实现的Web版报价系统

项目的原因需要实现基于Web版的网上报价查询系统。用户需求很简单就是客户通过登录网站后,可以对产品提交买卖价格,系统有个集中展示屏幕来展示10档最优买入和卖出价格。对于上述功能的实现无外乎有两种实现方式:

推送(Push)技术:

一种建立在服务器上的机制,由服务器主动将信息发往客户端的技术。Push技术的优势在于信息主动性和及时性。

拉(Pull)技术:

客户机主动请求信息,采用客户端定时刷新页面,可使用Ajax技术实现,每隔N秒自动Reload一次,如果在此期间Server端数据发生变化,客户端可以获取新的内容。

根据我们的需求,采用推送技术来实现上述功能是个比较好的选择。经过技术选型,最终选择使用Pushlet框架。Pushlet采用观察者模式,客户端订阅服务器感兴趣的事件,服务器端为每个客户端分配一个Session ID为标记,事件源会把新产生俄事件以多播的方式发送到订阅者的事件队列里。具体原理这里不作过多介绍,本文主要介绍一下使用Pushlet实现的一个计算报价平均值的Demo。

新建一个QuoteServlet.类,一个Servlet用于实现从客户端提交用户的报价,并触发服务器端发送价格变动事件。

package com;

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/*
 * Servlet方法实现数据的提交
 */
public class QuoteServlet extends HttpServlet{

	private static final long serialVersionUID = 2386052823761867369L;
	public static Double ttPrice = 0.00;

	public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{

		// 调用 HttpServlet 自带的日志函数输出信息到控制台
		this.log("执行 doGet 方法... ");
		// 处理 doPost
		this.execute(request, response);

		//调用pushlet更新对方的数据
		String valueString = Double.toString(ttPrice);
		QuotePushlet.sendByMulticast(valueString);

	}

	/**
	 * 以 POST 方式访问页面时执行该函数。
	 */
	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {

		this.log("执行 doPost 方法... ");

		// 处理 doPost
		this.execute(request, response);

		//调用pushlet更新对方的数据
		String valueString = Double.toString(ttPrice);
		//定向广播
		//QuotePushlet.sendByMulticast(valueString);
		//定向发送
		QuotePushlet.sendByUnicast(valueString);
		//QuotePushlet.sendByBroadcast(valueString);
	}

	private void execute(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException{

		String priceString = getReqStr(request.getParameter("qprice"),true);
		Double priceDb = 0.0;

		if (priceString != null && priceString != ""){
			priceDb = Double.valueOf(priceString);
		}  

		if (ttPrice != 0.00){
			ttPrice = ttPrice + priceDb;
			ttPrice = ttPrice/2;
		}else{
			ttPrice = priceDb;
		}

	}

    private  String getReqStr(Object s,boolean isGetMethod){
    	if(s==null) return "";
    	if(!isGetMethod) return ((String)s).toString();
    	try{
    	   return new String(((String)s).toString().getBytes("ISO8859_1"), "GBK");
    	}catch(Exception e){
    	   return "";
    	}
    }

}

创建QuotePushlet类,用于实现事件广播。我这边分别使用了Pushlet的unicast,multicast,broadcast来发送广播事件。其中unicast是定向发,multicast,broadcast都是全局广播。

package com;

import java.util.HashMap;
import java.util.Map;

import nl.justobjects.pushlet.core.Dispatcher;
import nl.justobjects.pushlet.core.Event;
import nl.justobjects.pushlet.core.Session;
import nl.justobjects.pushlet.core.SessionManager;

/*
 * 使用push的broadcast,multicast,unicast方法
 *
 * 实现数据的展示
 */
public class QuotePushlet {

	public static void sendByMulticast(String value){

		Map<String, String> map = new HashMap<String, String>();
		map.put("avgPrice", value);
		Event event = null;
		event = Event.createDataEvent("/quote/newPrice", map);

		//群发广播
		Dispatcher.getInstance().multicast(event);
	}

	public static void sendByUnicast(String value){

		Map<String, String> map = new HashMap<String, String>();
		map.put("avgPrice", value);
		Event event = null;
		event = Event.createDataEvent("/quote/newPrice", map);

		Session[] sessions = SessionManager.getInstance().getSessions();
		for ( Session session : sessions ) {
			//定向发送
			Dispatcher.getInstance().unicast(event, session.getId());
		}

	}

	public static void sendByBroadcast(String value){

		Map<String, String> map = new HashMap<String, String>();
		map.put("avgPrice", value);
		Event event = null;
		event = Event.createDataEvent("/quote/newPrice", map);

		Dispatcher.getInstance().broadcast(event);
	}

}

使用pushlet需要在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">
	<!-- Define the pushlet servlet -->
	<servlet>
		<servlet-name>pushlet</servlet-name>
		<servlet-class>nl.justobjects.pushlet.servlet.Pushlet</servlet-class>
		<load-on-startup>3</load-on-startup>
	</servlet>
	<!-- Define the Servlet Mappings. -->
	<!-- The pushlet -->
	<servlet-mapping>
		<servlet-name>pushlet</servlet-name>
		<url-pattern>/pushlet.srv</url-pattern>
	</servlet-mapping>

	<servlet>
		<servlet-name>quoteServlet</servlet-name>
		<servlet-class>
			com.QuoteServlet
		</servlet-class>
	</servlet>
	<servlet-mapping>
		<servlet-name>quoteServlet</servlet-name>
		<url-pattern>/quoteServlet</url-pattern>
	</servlet-mapping>
</web-app>

另外还需要pushlet.properties和sources.properties,这里不表啦。

报价的JSP页面代码如下:

<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>quote</title>

   <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
   <meta http-equiv="Pragma" content="no-cache">
   <script type="text/javascript" src="ajax-pushlet-client.js"></script>
   <link rel="stylesheet" type="text/css" href="./script/easyui/jquery-easyui-1.3.5/easyui.css" >
<link rel="stylesheet" type="text/css" href="./script/easyui/jquery-easyui-1.3.5/icon.css" >
	<script type="text/javascript" src="./script/easyui/jquery.min.js"></script>
	<script type="text/javascript" src="./script/easyui/jquery.easyui.min.js"></script>
   	<style type="text/css" ID="PageStyle">
		body, td
		{
		     background: #ffffff;
		     color: #000000;
		     font-size: 14px;
		     font-family : verdana, sans-serif;
		}
		body {
		    margin-left: 8px;
		    margin-right: 0px;
		}
		.head {
		    color: #111111;
		}
	</style>

	<script type="text/javascript">

		function QuotationPost(){
			  $.ajax({
				type: "post",
				 url: "quoteServlet",
				 dataType: "text",
				 data:{qprice:$("#formqprice").val()},
				 success: function (data) { 

				 },
				 error: function (XMLHttpRequest, textStatus, errorThrown) {
				    alert(errorThrown);
				 }
	         });
		}
	</script>
</head>
<body>

<div>
<span>当前债券的平均价格是</span>
  <span id="qprice"></span>
  <br>
</div>

<div>
  <span>我要报价:</span>
  <div style="font-size: 20px;" >
	   <form id="QuotationForm" method="post"  >
		    <table>
			  <tr>
				 <td colspan="3" >
				             报价:     <input name="qprice" id="formqprice"     type="text"    style="width:100px"  />
				 </td>
			  </tr>
			  <tr>
			  	 <td colspan="2" >
			  	    <input type="button" value="提交报价" onclick="QuotationPost();" />
			  	 </td>
			  </tr>
			</table>
	   </form>
  </div>
</div>

</body>
</html>

价格展示的前台页面如下:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
	<head>
		<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
		<meta http-equiv="Pragma" content="no-cache" />
		<script type="text/javascript" src="ajax-pushlet-client.js"></script>
		<script type="text/javascript">
			PL._init();
			PL.joinListen('/cuige/he');
			function onData(event) {
				//alert(event.get("mmdata"));
				// 离开
				// PL.leave();
				var kbDom = document.getElementById('kb');
				var kb = event.get("mess");
				//alert(event.get("mmdata"));
				kbDom.innerHTML = kb;
			}
		</script>
	</head>
	<body>
		当前债券平均价格:<span id="kb">...</span>元
	</body>
</html>
时间: 2024-12-30 10:09:29

基于Pushlet实现的Web版报价系统的相关文章

[转]建立大容量基于Web的Email系统

建立大容量基于Web的Email系统 王波 最近几年来,基于Web的免费Email系统非常流行.当前,几个著名的免费Email网站基本上已经成为大多数人的选择,建立单纯提供免费Email服务的站点不再像以前那样受到热烈欢迎,但是提供Web界面的Email服务已经成为了一个商业站点为其注册成员提供的基本服务之一. 一个Email系统可以分为服务器端和客户端,Web界面的Email系统则是将Email客户放在了Web服务器端,因此Email系统所需要实现的是一个Web界面的Email客户.然而,由于

Node学习笔记(三):基于socket.io web版你画我猜(一)

经过惨淡的面试,也是知道了自己的不足,刚好最近在学习node,心中便有了做一个web版的你画我猜的想法 首先说下思路,在做准备工作的时候,有两个大概的思路: 1.规定一块div,捕捉鼠标事件,动态生成position absolute,长宽1px的红色小div,这样可以模拟出划线的轨迹,做一个long polling,不断获取DOM结构,推送到socket端口,然后再广播给所有客户端 2.利用canvas作图,将canvas的数据推送到socket端口,广播所有客户端 其实之所以有两种想法,无非

Graylog2进阶 打造基于Nginx日志的Web入侵检测分析系统

对于大多数互联网公司,基于日志分析的WEB入侵检测分析是不可或缺的. 那么今天我就给大家讲一讲如何用graylog的extractor来实现这一功能. 首先要找一些能够识别的带有攻击行为的关键字作为匹配的规则. 由于我不是专门搞安全的,所以在网上找了一些软waf的规则脚本. 剩下来的工作就可以交给Graylog的extractor实现了. 这次介绍一下extractor的Copy input用法. (1)waf规则脚本如下: \.\./ select.+(from|limit) (?:(unio

Web版的各种聊天工具

直到近期为止,我们经常使用的即时聊天工具(QQ.msn等)了Web版,大家不用下载庞大软件,直接打开网页就能够与自己的好友聊天,非常方便.在此将时汇总 ?????? 便于大家查找 ?????? 节约大家一点时间 此都是官方站点 ?????? 请大家放心使用: 1.先说我们最经常使用的QQ 在线聊天Web版地址: http://webqq.qq.com/ (刚建的 ?????? 现正在測试 ?????? 须要申请 ?????? 日前还不太稳定 ?????? 有待完好) 2.msn在线聊天Web版地

简易版支付系统部署(单节点) 吴水成

一.前期准备 1.MySQL数据库的安装:MySQL-5.6.22,自行安装 2.Dubbo视频教程--基础篇--第03节--ZooKeeper注册中心安装 3.Dubbo视频教程--基础篇--第06节--Dubbo管理控制台的安装 4.Dubbo视频教程--基础篇--第10节--Dubbo监控中心的介绍与简易监控中心的安装 5.持续集成管理平台(SVN.Nexus.Maven.Hudson)的安装: Dubbo视频教程--基础篇--第11节至18节 6.Dubbo视频教程--高级篇--第21节

构建一个基于 Spring 的 RESTful Web Service

本文详细介绍了基于Spring创建一个“hello world” RESTful web service工程的步骤. 目标 构建一个service,接收如下HTTP GET请求: http://localhost:8080/greeting 并返回如下JSON格式的问候语: {"id":1,"content":"Hello, World!"} 你也可以通过指定查询字符串中的可选参数name来定制问候语: http://localhost:8080

Dubbo高级篇教程--支付系统开发 之 简易版支付系统部署(单节点)

一.前期准备 1.MySQL数据库的安装:MySQL-5.6.22,自行安装 2.Dubbo视频教程--基础篇--第03节--ZooKeeper注册中心安装 3.Dubbo视频教程--基础篇--第06节--Dubbo管理控制台的安装 4.Dubbo视频教程--基础篇--第10节--Dubbo监控中心的介绍与简易监控中心的安装 5.持续集成管理平台(SVN.Nexus.Maven.Hudson)的安装: Dubbo视频教程--基础篇--第11节至18节 6.Dubbo视频教程--高级篇--第21节

支付系统开发--简易版支付系统部署(单节点)

一.前期准备 1.MySQL数据库的安装:MySQL-5.6.22,自行安装 2.Dubbo视频教程--基础篇--第03节--ZooKeeper注册中心安装 3.Dubbo视频教程--基础篇--第06节--Dubbo管理控制台的安装 4.Dubbo视频教程--基础篇--第10节--Dubbo监控中心的介绍与简易监控中心的安装 5.持续集成管理平台(SVN.Nexus.Maven.Hudson)的安装: Dubbo视频教程--基础篇--第11节至18节 6.Dubbo视频教程--高级篇--第21节

RDIFramework.NET Web版介绍

RDIFramework.NET  Web版介绍 B/S结构(Browser/Server,浏览器/服务器模式),是WEB兴起后的一种网络结构模式,WEB浏览器是客户端最主要的应用软件.这种模式统一了客户端,将系统功能实现的核心部分集中到服务器上,简化了系统的开发.维护和使用.客户机上只要安装一个浏览器(Browser),如Netscape Navigator或Internet Explorer,服务器安装Oracle.Sybase.Informix或 SQL Server等数据库.浏览器通过W