blazeds推送技术至Flex zz
转自http://www.sloppy.cn/blog/article/247.htm
第一步下载blazeds.war
第二步修改两个配置文件:services-config.xml,messaging-config.xml
services-config.xml加入下面代码
程序代码
<channel-definition id="my-streaming-amf" class="mx.messaging.channels.StreamingAMFChannel">
<endpoint url="http://{server.name}:{server.port}/{context.root}/messagebroker/streamingamf" class="flex.messaging.endpoints.StreamingAMFEndpoint"/>
<properties>
<idle-timeout-minutes>0</idle-timeout-minutes>
<max-streaming-clients>10</max-streaming-clients>
<server-to-client-heartbeat-millis>5000</server-to-client-heartbeat-millis>
<user-agent-settings>
<user-agent match-on="MSIE" kickstart-bytes="2048" max-streaming-connections-per-session="1"/>
<user-agent match-on="Firefox" kickstart-bytes="2048" max-streaming-connections-per-session="1"/>
</user-agent-settings>
</properties>
</channel-definition>
messaging-config.xml加入下面的代码
程序代码
<destination id="tick-data-feed">
<properties>
<server>
<allow-subtopics>true</allow-subtopics>
<subtopic-separator>.</subtopic-separator>
</server>
</properties>
<channels>
<channel ref="my-polling-amf" />
<channel ref="my-streaming-amf" />
</channels>
</destination>
第三步:创建一个Servlet:
程序代码
package cn.bestwiz.design.tc.servlet;
import java.io.IOException;
import java.math.BigDecimal;
import java.util.Date;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import cn.bestwiz.design.tc.Tick;
import flex.messaging.MessageBroker;
import flex.messaging.messages.AsyncMessage;
import flex.messaging.util.UUIDUtils;
public class TickCacheServlet extends HttpServlet {
/**
*
*/
private static final long serialVersionUID = 1L;
private static FeedThread thread;
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
String cmd = req.getParameter("cmd");
if (cmd.equals("start")) {
start();
}
if (cmd.equals("stop")) {
stop();
}
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
// TODO Auto-generated method stub
super.doGet(req, resp);
}
@Override
public void destroy() {
// TODO Auto-generated method stub
super.destroy();
}
@Override
public void init() throws ServletException {
// TODO Auto-generated method stub
super.init();
}
public void start() {
if (thread == null) {
thread = new FeedThread();
thread.start();
}
System.out.println("start!!");
}
public void stop() {
thread.running = false;
thread = null;
}
public static class FeedThread extends Thread {
public boolean running = true;
public void run() {
MessageBroker msgBroker = MessageBroker.getMessageBroker(null);
String clientID = UUIDUtils.createUUID();
int i = 0;
while (running) {
Tick tick = new Tick();
tick.setAskPrice(new BigDecimal("100"));
tick.setBidPrice(new BigDecimal("100"));
tick.setMidPrice(new BigDecimal("100"));
tick.setTickTime(new Date());
tick.setSeqno(String.valueOf(i));
System.out.println(i);
AsyncMessage msg = new AsyncMessage();
msg.setDestination("tick-data-feed");
msg.setHeader("DSSubtopic", "tick");
msg.setClientId(clientID);
msg.setMessageId(UUIDUtils.createUUID());
msg.setTimestamp(System.currentTimeMillis());
msg.setBody(tick);
msgBroker.routeMessageToService(msg, null);
i++;
try {
Thread.sleep(20);
} catch (InterruptedException e) {
}
}
}
}
}
第四步:创建一个Java类:
程序代码
package cn.bestwiz.design.tc;
import java.math.BigDecimal;
import java.util.Date;
public class Tick {
private BigDecimal askPrice;
private BigDecimal bidPrice;
private BigDecimal midPrice;
private Date tickTime;
private String seqno;
public String getSeqno() {
return seqno;
}
public void setSeqno(String seqno) {
this.seqno = seqno;
}
public BigDecimal getAskPrice() {
return askPrice;
}
public void setAskPrice(BigDecimal askPrice) {
this.askPrice = askPrice;
}
public BigDecimal getBidPrice() {
return bidPrice;
}
public void setBidPrice(BigDecimal bidPrice) {
this.bidPrice = bidPrice;
}
public BigDecimal getMidPrice() {
return midPrice;
}
public void setMidPrice(BigDecimal midPrice) {
this.midPrice = midPrice;
}
public Date getTickTime() {
return tickTime;
}
public void setTickTime(Date tickTime) {
this.tickTime = tickTime;
}
}
第五步:
配置Flex项目:
Root Folder:C:\Program Files\Apache Software Foundation\Tomcat 6.0\webapps\blazeds
Root URL:http://localhost:8080/blazeds
Context Root:/blazeds
第六步:创建AS类:
程序代码
package cn.sloppy
{
[RemoteClass(alias="cn.bestwiz.design.tc.Tick")]
[Bindable]
public class Tick
{
public function Tick()
{
}
public var askPrice:Number;
public var bidPrice:Number;
public var midPrice:Number;
public var tickTimeate;;
public var seqno:String;
}
}
第七步:Flex主程序代码
程序代码
//
import mx.controls.Alert;
import mx.rpc.events.ResultEvent;
import mx.messaging.Consumer;
import mx.messaging.Channel;
import mx.messaging.ChannelSet;
import mx.messaging.events.MessageEvent;
//
[Bindable]
public var tick:Tick;
public function submsg():void
{
Alert.show("click start");
var consumer:Consumer = new Consumer();
consumer.destination = "tick-data-feed";
consumer.subtopic = "tick";
consumer.channelSet = new ChannelSet(["my-streaming-amf"]);
consumer.addEventListener(MessageEvent.MESSAGE, messageHandler);
consumer.subscribe();
Alert.show("click end");
}
private function messageHandler(event:MessageEvent):void
{
var tick:Tick = event.message.body as Tick;
txtTick.text = tick.seqno;
}
<mxanel x="524" y="47" width="362" height="302" layout="absolute" title="Watch Tick">
<mxabel x="72" y="43" text="Label" id="txtTick"/>
<mx:Button x="132" y="41" label="Button" click="submsg(); "/>
</mxanel>
第七步:运行Flex:http://localhost:8080/blazeds/HelloWorld-debug/HelloWorld.html?debug=true
点击Button
迂曲运行Servlet:http://localhost:8080/blazeds/TickCacheServlet?cmd=start
再看看Flex的效果:是不是文字一直在增长?
恭喜。成功了。
分享到:
相关推荐
在Blazeds中,向客户端推送数据主要涉及到以下几个关键组件和配置: 1. **通道定义(Channel Definition)**:在`services-config.xml`文件中,定义了数据传输的通道。例如,`StreamingAMFChannel`是一种支持流式...
在Flex客户端,我们需要配置MessageBroker以便接收来自服务器的推送数据。这通常涉及到在Flex配置文件(如services-config.xml)中定义StreamingAMFChannel,并设置其目的地。客户端代码会监听这些目的地,当有新...
传统的做法是客户端定时向服务器请求数据,而BlazDS提供的StreamingAMFChannel通道则支持服务器主动推送数据到客户端,提高了效率并减少了不必要的网络通信。 1. BlazDS简介: BlazDS是一款开源的Adobe Flex与Java...
数据源通常是一个ArrayCollection,它可以实时接收来自BlazeDS的推送数据。每当服务器端有新的数据可用,BlazeDS会自动将这些数据推送给客户端,更新ArrayCollection,从而触发lineChart的更新。 此外,为了实现...
这个技术允许双向通信,即服务器可以主动向客户端推送数据,而不仅仅是响应客户端的请求。这种功能对于实时性要求高的应用,如股票交易、聊天室或者实时数据显示等场景非常有用。 在"BlazeDS实现java后台消息推送...
标题中的“flex+spring+blazeds消息推送”是指在开发富互联网应用程序(RIA)时,采用Adobe Flex作为前端UI框架,Spring作为后端服务层框架,BlazeDS作为数据通信中间件,实现服务器到客户端的消息实时推送功能。...
在Flex应用程序中,消息推送是一项关键特性,它允许服务器主动向客户端发送数据,而无需客户端持续发起请求。这种技术提高了用户体验,因为它减少了不必要的网络延迟,并且在数据更新时能够即时反馈给用户。 消息...
3. **Live Data Push**:BlazeDS支持服务器向客户端推送数据,而不仅仅是响应客户端请求。这种推送技术(如Long Polling、Comet等)使得实时应用(如股票交易、聊天室等)成为可能,无需客户端不断轮询服务器。 4. ...
BlazeDS支持实时双向通信,包括HTTP长轮询、HTTP流和WebSocket等技术,使得服务器能够主动向客户端推送数据,而非传统的请求-响应模式。 **Flex简介** Flex是基于MXML和ActionScript的开发框架,用于构建具有丰富...
在Flex和Java集成中,通过BlazeDS支持WebSocket,可以实现真正的实时推送,即服务器可以直接将数据推送到客户端,无需客户端轮询。 在实际应用中,开发人员需要在Java服务器端创建处理推送逻辑的服务,并在Flex...
在本场景中,我们将探讨如何利用BlazeDS和Flex实现服务器消息推送。 首先,让我们了解BlazeDS的基本概念。BlazeDS是Adobe Flex与Java后端进行数据交互的一个中间件,它支持AMF(Action Message Format)协议,能够...
flex blazeds实现服务器向客户端推送数据 环境Eclipse Java EE IDE 服务apache-tomcat-7.0.23-windows-x86 blazeds采用的是blazeds4.0.0.14931 (附件中包含 apache-tomcat-7.0.23 + 源码 + 说明文档)
3. **数据推送**:与传统的HTTP请求不同,BlazeDS可以通过Long Polling、HTTP Streaming或WebSocket等技术实现服务器向客户端的主动数据推送,这在实时性要求高的应用如股票交易、聊天室或在线游戏等场景下非常有用...
相反,我们可以利用BlazeDS中的StreamingAMFChannel技术,实现服务器向客户端推送数据,提高实时性和效率。 BlazeDS是一个开源的Java服务器端组件,能够为Flex和Ajax应用提供数据集成。它支持多种通信协议,包括...
2. **Message Brokering**:Blazeds支持发布/订阅消息模型,允许客户端订阅服务器上的事件,当服务器状态改变时,可以自动推送更新到客户端,实现实时通信。 3. **Live Data Services**:Blazeds提供了对Flex数据...
BlazeDS支持服务器向客户端推送数据的机制,这在实时应用中非常关键,如股票交易、在线聊天或实时数据更新。通过Long Polling、HTTP Streaming或WebSocket等技术实现,可以实现低延迟的数据同步。 4. **Remoting**...
BlazeDS还支持WebSocket,可以实现双向通信,即服务器可以主动向客户端推送数据,非常适合实时应用。 总结来说,`blazeds.zip`文件是Flex开发者与Java后端进行数据交互的关键工具,它提供了数据服务、AMF支持以及...
3. **MessageBroker**:MessageBroker是BlazeDS中的消息中间件,它支持发布/订阅模式的消息传递,允许服务器主动向客户端推送数据,而不是仅仅依赖客户端的请求。这种推送机制对于实时性要求高的应用非常有用,如...
3. **数据推送**:BlazeDS支持服务器向客户端推送数据,这在实时应用中非常重要,比如股票交易、在线游戏和协作工具等。 4. **数据服务**:RemoteObject、LiveCycle Data Services (LCDS) 和 Flex Data Services ...