Fms3中client端与server端交互方式汇总

简介:

fms3中server端代码是写在asc文件中,客户端是broadcastMsg.swf

2者交互方式我总结如下:

1. 客户端呼叫服务器
服务器端main.asc代码如下:

复制代码

Client.prototype.serverFun1 = function(value)
{
    return "value="+value
};
复制代码

客户端代码如下:

复制代码

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" 
    fontSize
="12" creationComplete="init()">
    
    
<mx:Script>
        
<![CDATA[    
        import mx.controls.Alert;
    
        private var netConnection:NetConnection;
        private var responder:Responder;
        private var appServer:String="rtmp://192.168.0.249/TestCode1";
            
        private function init():void
        {
            netConnection = new NetConnection();
            netConnection.connect(appServer);
            netConnection.client=this;
        }
        
        private function onClick(evt:MouseEvent):void
        {
            responder = new Responder(OkFun,ErrorFun);
            netConnection.call("serverFun1",responder,"va");
        }
            
        private function OkFun(re:String):void
        {
            Alert.show(re);
        }
        
        private function ErrorFun(info:Object):void
        {
            Alert.show( "error: " + info.description );
            Alert.show( "error: " + info.code );
        }
        
        
]]>
    
</mx:Script>

    
<mx:Button x="43" y="65" label="调用服务器" id="btn" click="onClick(event)"/>
    
</mx:Application>

复制代码


代码说明:
Responder 类提供了一个对象,该对象在 NetConnection.call() 中使用以处理来自与特定操作成功或失败相关的服务器的返回值。
它有2个参数:第1个是成功调用回调的方法,第2个参数是调用失败时回调的方法

call () 方法   
public function call(command:String, responder:Responder, ... arguments):void 
第1个参数:服务器端方法名
第2个参数:可选对象,用于处理服务器的返回值
第3个参数:传递给服务器端方法的值
 
本例题:点击按钮后,调用asc文件中的serverFun1方法,并传递参数“va”给它,serverFun1方法处理后方法一个值,要是成功就回调OkFun,并显示“value=va”字符串,要是调用失败(可能会遇到特定于当前操作的网络操作错误或与当前连接状态有关的错误)将回调ErrorFun,并显示错误信息

 

2. 服务器端呼叫指定的客户端
服务器端main.asc代码如下:

Code

客户端代码如下:

Code


代码说明:
Client.call() 在Flash客户机上异步的执行一个方法,并把值从Flash客户机返回到服务器。
用法 clientObject.call(methodName, [resultObj, [p1, ..., pN]])
第1个参数:客户端的方法名
第2个参数:当发送者期待一个来自客户机的返回值时需要这个参数。如果参数被传递但没有返回值被期待的话,则传递值null。结果对象可以是你定义的任何对象,并且,为了有用起见,这个结果对象应该有两个方法-onResult和onStatus,这些方法会在结果到达时被调用。如果远端方法的调用是成功的,则resultObj.onResult事件会被触发;否则,resultObj.onStatus事件将被触发。
第3个参数:传递给客户端的方法的值

本例题:启动后,连接成功,服务器接收请求,并调用改客户端的asyncServerCall方法(必须公有),asyncServerCall方法处理后返回值,要是处理成功onResult事件就被触发,要是处理失败onStatus事件就被触发。

3. 服务器端呼叫所有的客户端(广播)
服务器端main.asc代码如下:

复制代码

application.onConnect = function(currentClient)
{
    application.acceptConnection(currentClient);
    application.broadcastMsg("showServerMsg",application.clients.length );
}
复制代码

客户端代码如下:

复制代码

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute"
 fontSize
="12" creationComplete="init()">
    
    
<mx:Script>
        
<![CDATA[
            
        import mx.controls.Alert;
        
        private var netConnection:NetConnection;
        private var appServer:String="rtmp://192.168.0.249/TestCode1";
        
        private function init():void
        {
            netConnection = new NetConnection();
            netConnection.connect(appServer);
            netConnection.client=this;
        }
        
        public function showServerMsg( n:Number ) :void
           {
               var msg:String ="已经有"+n.toString()+"位用户连接";
               Alert.show( msg );
           }
                
        
]]>
    
</mx:Script>
    
</mx:Application>
复制代码


代码说明:
Application.broadcastMsg():把一条消息广播到所有连接的客户机,给每个客户机广播
这个方法相当于循环遍历Application.clients数组并在每一个独立的客户机上调用Client.call(),但这个方法的效率更高(尤其是当连接的客户机数量很大时)。唯一的不同是当你调用broadcastMsg()时你不能指定一个响应对象,除此以外,两种语法是一样的。
等同于如下:
//遍历客户端列表,分别call他们
for(var i=0;i<application.clients.length;i++) {
 application.clients[i].call("showServerMsg",application.clients.length);
}

本例题:一旦有客户机连接fms,就给每个连接的客户机广播,并显示出"已经有n位用户连接"

4. 服务器端呼叫服务器端
NetConnection.call
用法: 
NetConnection.call(methodName, [resultObj, p1, ..., pN]) 
调用一个 Flash Communication Server 或者其他应用服务器上的命令或方法。用法和客户端的 NetConnection.call 的用法一样。他调用一个远程服务器上的方法。我就没贴代码



    本文转自 OldHawk  博客园博客,原文链接:http://www.cnblogs.com/taobataoma/archive/2010/12/05/1896748.html,如需转载请自行联系原作者




相关文章
Server-Sent Events 和 WebSocket 之间有什么区别
Server-Sent Events (SSE) 和 WebSocket 分别代表单向和双向通信机制。SSE,基于 HTTP,仅允许服务器向客户端发送事件流;而 WebSocket 是双向实时通信协议,支持客户端与服务器的双向交互。SSE适合低实时性场景,依赖长轮询或流传输;WebSocket 提供更低延迟,适用于高实时性应用。两者在现代浏览器中普遍被支持,但旧版浏览器或特定网络环境可能影响兼容性。选择哪种机制取决于实际需求,如通信方向、实时性要求及目标浏览器支持。
|
5月前
|
API 开发者
【API管理 APIM】APIM集成内部VNet后,自我访问出现(Unable to connect to the remote server)问题,而Remote Server正是APIM它自己
【API管理 APIM】APIM集成内部VNet后,自我访问出现(Unable to connect to the remote server)问题,而Remote Server正是APIM它自己
117 5
|
Web App开发 前端开发 安全
基础:BS(Browser/Server)、CS(Client/Server)架构
基础:BS(Browser/Server)、CS(Client/Server)架构
606 0
|
网络协议
UDP Server/Client
UDP Server/Client
247 0
|
中间件
OWIN的理解和实践(二) – Host和Server的开发
原文:OWIN的理解和实践(二) – Host和Server的开发 对于开发人员来说,代码就是最好的文档,如上一篇博文所说,下面我们就会基于Kanata项目的一些具体调用代码,来进一步深入理解OWIN的实现和作用.
1636 0
|
内存技术 应用服务中间件