`

blazeds向客户端推送数据

阅读更多
 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向客户端推送数据.

    在Blazeds中,向客户端推送数据主要涉及到以下几个关键组件和配置: 1. **通道定义(Channel Definition)**:在`services-config.xml`文件中,定义了数据传输的通道。例如,`StreamingAMFChannel`是一种支持流式...

    flex采用blazeds实现服务器向客户端推数据

    在Flex客户端,我们需要配置MessageBroker以便接收来自服务器的推送数据。这通常涉及到在Flex配置文件(如services-config.xml)中定义StreamingAMFChannel,并设置其目的地。客户端代码会监听这些目的地,当有新...

    flex采用blazeds实现服务器向客户端推数据.doc

    传统的做法是客户端定时向服务器请求数据,而BlazDS提供的StreamingAMFChannel通道则支持服务器主动推送数据到客户端,提高了效率并减少了不必要的网络通信。 1. BlazDS简介: BlazDS是一款开源的Adobe Flex与Java...

    Flex BlazeDs 推数据生成lineChart实例

    数据源通常是一个ArrayCollection,它可以实时接收来自BlazeDS的推送数据。每当服务器端有新的数据可用,BlazeDS会自动将这些数据推送给客户端,更新ArrayCollection,从而触发lineChart的更新。 此外,为了实现...

    BlazeDS实现java后台消息推送flex前台接收的例子

    这个技术允许双向通信,即服务器可以主动向客户端推送数据,而不仅仅是响应客户端的请求。这种功能对于实时性要求高的应用,如股票交易、聊天室或者实时数据显示等场景非常有用。 在"BlazeDS实现java后台消息推送...

    flex+spring+blazeds消息推送

    标题中的“flex+spring+blazeds消息推送”是指在开发富互联网应用程序(RIA)时,采用Adobe Flex作为前端UI框架,Spring作为后端服务层框架,BlazeDS作为数据通信中间件,实现服务器到客户端的消息实时推送功能。...

    消息推送 blazeds

    在Flex应用程序中,消息推送是一项关键特性,它允许服务器主动向客户端发送数据,而无需客户端持续发起请求。这种技术提高了用户体验,因为它减少了不必要的网络延迟,并且在数据更新时能够即时反馈给用户。 消息...

    blazeDs解决flex客户端与Server的远程通讯

    3. **Live Data Push**:BlazeDS支持服务器向客户端推送数据,而不仅仅是响应客户端请求。这种推送技术(如Long Polling、Comet等)使得实时应用(如股票交易、聊天室等)成为可能,无需客户端不断轮询服务器。 4. ...

    blazeds和flex整合

    BlazeDS支持实时双向通信,包括HTTP长轮询、HTTP流和WebSocket等技术,使得服务器能够主动向客户端推送数据,而非传统的请求-响应模式。 **Flex简介** Flex是基于MXML和ActionScript的开发框架,用于构建具有丰富...

    Flex与Java的消息推送

    在Flex和Java集成中,通过BlazeDS支持WebSocket,可以实现真正的实时推送,即服务器可以直接将数据推送到客户端,无需客户端轮询。 在实际应用中,开发人员需要在Java服务器端创建处理推送逻辑的服务,并在Flex...

    基于Java_BlazeDS_Flex_服务器消息推的聊天室

    在本场景中,我们将探讨如何利用BlazeDS和Flex实现服务器消息推送。 首先,让我们了解BlazeDS的基本概念。BlazeDS是Adobe Flex与Java后端进行数据交互的一个中间件,它支持AMF(Action Message Format)协议,能够...

    Flex BlazeDS

    flex blazeds实现服务器向客户端推送数据 环境Eclipse Java EE IDE 服务apache-tomcat-7.0.23-windows-x86 blazeds采用的是blazeds4.0.0.14931 (附件中包含 apache-tomcat-7.0.23 + 源码 + 说明文档)

    blazeds4.7官方下载

    3. **数据推送**:与传统的HTTP请求不同,BlazeDS可以通过Long Polling、HTTP Streaming或WebSocket等技术实现服务器向客户端的主动数据推送,这在实时性要求高的应用如股票交易、聊天室或在线游戏等场景下非常有用...

    Flex的数据推送问题解决方案

    相反,我们可以利用BlazeDS中的StreamingAMFChannel技术,实现服务器向客户端推送数据,提高实时性和效率。 BlazeDS是一个开源的Java服务器端组件,能够为Flex和Ajax应用提供数据集成。它支持多种通信协议,包括...

    blazeds flash开源服务器

    2. **Message Brokering**:Blazeds支持发布/订阅消息模型,允许客户端订阅服务器上的事件,当服务器状态改变时,可以自动推送更新到客户端,实现实时通信。 3. **Live Data Services**:Blazeds提供了对Flex数据...

    flex blazeDS开发使用手册,对于集成blaze开发很有用处。

    BlazeDS支持服务器向客户端推送数据的机制,这在实时应用中非常关键,如股票交易、在线聊天或实时数据更新。通过Long Polling、HTTP Streaming或WebSocket等技术实现,可以实现低延迟的数据同步。 4. **Remoting**...

    blazeds.zip文件

    BlazeDS还支持WebSocket,可以实现双向通信,即服务器可以主动向客户端推送数据,非常适合实时应用。 总结来说,`blazeds.zip`文件是Flex开发者与Java后端进行数据交互的关键工具,它提供了数据服务、AMF支持以及...

    blazeds 3-0-0-544

    3. **MessageBroker**:MessageBroker是BlazeDS中的消息中间件,它支持发布/订阅模式的消息传递,允许服务器主动向客户端推送数据,而不是仅仅依赖客户端的请求。这种推送机制对于实时性要求高的应用非常有用,如...

    blazeds-bin-4.0.0.15974.zip

    3. **数据推送**:BlazeDS支持服务器向客户端推送数据,这在实时应用中非常重要,比如股票交易、在线游戏和协作工具等。 4. **数据服务**:RemoteObject、LiveCycle Data Services (LCDS) 和 Flex Data Services ...

Global site tag (gtag.js) - Google Analytics