ShareObject介绍:

1 ShareObject,顾名思义共享对象,而通常意义上的共享,从B/S结构上来讲,无非是客户端(浏览器端)的共享和服务器端的共享了,不错,ShareObject刚好份演了这两种角色。而且ShareObject也是按此进行了两种分类,一类是LSO——Local Share Object(本地共享对象)其实类似于cookie,而另一种RSO——Remote Share Object(远程共享对象) 我感觉比较类似于JSP中的Application对象,但好象比Application更强大。

2.存储位置 
以 Windows为例,目录为 
C:\Documents and Settings\[ username ] \\Application Data\\Macromedia\\Flash 
Player\\#SharedObjects\\ [ random character directory name ] , 在Mac OS X 上, 目录为 
/Users/[ username ] /Library/Preferences/Macromedia/Flash Player/#SharedObject/ [ random 
character directory name ]。随机字符目录命名是为了安全考虑

下面我分别用实例代码来说两者的用法和用途:

一:LSO(本地共享对象)

LSO的用法比较简单,和我们平常操作Cookie大同小异:

1.得到一个共享对象:

var so:SharedObject=SharedObject.getLocal("mydata","/");

2.往共享对象里存入值:

var user:Object=new Object();

user.userName=userName.text;

user.passWord=passWord.text;

user.isSaveLogin=(remember.selected==true?1:0);

so.data.user=user;

3.清除共享对象里的值:

var so:SharedObject=SharedObject.getLocal("mydata","/");

if(so.data.user!=null){

so.data.user=null;

}

4.读取共享对象里的值:

var so:SharedObject=SharedObject.getLocal("mydata","/");

if(so.data.user!=null){

userName.text=so.data.user.userName;

passWord.text=so.data.user.passWord;

if(so.data.user.isSaveLogin.toString()=="1"){

remember.selected=true;

}

二:RSO(远程共享对象):

RSO是服务器端的共享对象,服务器端的数据共享可以实现多个客户端数据共享,在这里服务器我采用Flash Media Server3,FMS的使用非常简便,你只要在安装目录下找到Applications目录,并在其下新建一个子目录就可以成为你的工程或项目了。关于FMS的使用大家可以参考相关文章,本文不做介绍:利用FMS和RSO我们可以实现非常多的功能,诸如,聊天室,联机游戏,视频会议,在线视频录制和视频聊天。。。。。。

在这里我用一个简单的聊天室实例为例稍做讲解:

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" creationComplete="TextSO ();"><mx:Script><![CDATA[import flash.events.SyncEvent;import flash.events.NetStatusEvent;import flash.events.MouseEvent;import flash.net.SharedObject;import flash.net.NetConnection;private var text_so:SharedObject;private var nc:NetConnection;private var rtmpGo:String;private var good:Boolean;public function TextSO ():void{ button.label="Send";button.addEventListener (MouseEvent.CLICK,sendMsg);//为发送按钮添加发送事件rtmpGo = "rtmp://localhost/basicSO";//这里设置FMS服务器的连接地址,basicSO即为,//FMS安装目录下Applications下自己手动新建的一个文件夹名称,也是FMS的工程名,就是这么简洁,不可意议nc = new NetConnection( );//产生一个连接对象nc.connect (rtmpGo);//连接到上面的地址nc.addEventListener (NetStatusEvent.NET_STATUS,doSO);//加入连接的监听事件,以便根据连接返回的状态做相应处理
        }private function doSO (e:NetStatusEvent):void{    good=e.info.code == "NetConnection.Connect.Success";//判断是否为连接成功状态//连接返回的状态有好几种,大家可以参看FMS的文档,很详尽if (good)//如果连接成轼,执行如下操作
             {text_so=SharedObject.getRemote("test",nc.uri,false);//得到远程共享对象,false属性是设置共享的数据为非持久化的,//即重启服务器后,先前的数据不会保存
                   text_so.connect (nc);text_so.addEventListener (SyncEvent.SYNC,checkSO);//为共享对象添加异步事件,这也是服务器同步处理多客户端最关键的地方,//一个客户端进行了什么操作,其它客户端也会有相应的变化,就是通过此事件来完成的
             }}private function checkSO (e:SyncEvent):void{for (var chng:uint; chng<e.changeList.length; chng++){switch (e.changeList[chng].code){case "clear" :break;case "success" :trace (text_so.data.msg);break;case "change" ://一个客户端改变数据会更新所有客户端textArea.htmlText+=text_so.data.msg + "\n";break;}}}private function sendMsg (e:MouseEvent):void{text_so.setProperty ("msg",textInput.text);//将新的信息存入共享对象textArea.htmlText+=text_so.data.msg + "\n";//更新客户端的信息列表
        }]]></mx:Script><mx:VBox><mx:TextArea id="textArea" width="200" height="200"/>//信息列表框<mx:TextInput id="textInput"/>//消息输入框<mx:Button id="button" />//发送按钮</mx:VBox>
</mx:Application>

转载于:https://www.cnblogs.com/coolsundy/p/4899052.html

FLEX SharedObject介绍及应用相关推荐

  1. 2.React Native Flex布局介绍以及实践

    好久没有写博客,一直在用自己的印象笔记记录一些问题.2017年了,想重新的把博客写起来.也希望通过这个平台交一些朋友. 没有具体的介绍基本的语法,主要是说明了与标准的CSS Flex的一些区别以及一个 ...

  2. 最简单的flex布局介绍(转自阮一峰)及筛子案例

    大佬阮一峰在15年的博客至今我认为无人可以超越 所以就直接引用他的博客 Flex 布局教程:语法篇 - 阮一峰的网络日志 (ruanyifeng.com) 在引用之后为一个flex布局小demo Fl ...

  3. 微信小程序布局display flex布局介绍

    display flex是什么? 微信小程序最近火的不要不要的,下载开发工具测试了一下,小程序对css支持很好, 布局使用display flex布局火力强大,不太了解或者对flex布局比较生疏的童靴 ...

  4. Flash本地共享对象 SharedObject

    以下内容是对网上一些资料的总结 Flex SharedObject 介绍(转自http://www.eb163.com/club/thread-3235-1-1.html): Flash的本地共享对象 ...

  5. JavaScript 5/30:Flex Panel Gallery即FLEX布局的图片库

    JavaScript30 为Wes Bos推出的一项为期30天的挑战,旨在帮助人们用纯JavaScript来实现效果,初学者若想在JS方面快速精进,不妨一试.本题为第五题. 实现效果 点击任意一张图片 ...

  6. Flex与.NET互操作(十六):FluorineFx + Flex视频聊天室案例开发

    本文将使用FluorineFx和Flex结合介绍一个简单的视频聊天室案例开发,希望通过此篇和大家交流FluorineFx和Flex的相关技术,同时也希望本篇可以帮助到需要使用FluorineFx做及时 ...

  7. image 微信小程序flex_微信小程序进阶-flex布局

    对于一个后端程序员来说最麻烦的就是布局了,今天就介绍下小程序的布局,介绍一种高效的小程序布局方案.笔者之前也做过native app的布局,对比下来,小程序的布局没有native那么灵活,毕竟goog ...

  8. 你不能只会flex居中布局,精制动画讲解所有flex布局方式,通俗易懂教程

    flex布局相信很多人都已经有不少了解,其优势和作用被越来越多的开发者所喜爱,网上也有很多关于关于flex的介绍和教程.但是根据笔者的面试经验发现,很多人尤其是初中级开发者对flex布局都仅仅停留下c ...

  9. CSS中flex的用法( 学习笔记 )

    flex( 弹性盒.伸缩盒 ) flex 的介绍 flex是CSS中的又一种布局手段,它主要用来代替浮动来完成页面的布局 flex可以使元素具有弹性,让元素可以随页面的大小的改变而改变 弹性容器 要使 ...

最新文章

  1. c语言包括在方括号中的序号称为,自考《高级语言程序设计》知识点总结(四)...
  2. 零基础自学python的建议-关于零基础学习 Python 有什么好的建议?
  3. angularJS(5)
  4. Spring mvc ContextLoaderListener 原理解析
  5. C++内部类访问外部类
  6. Crontab中shell每分钟执行一次HDFS文件上传不执行的解决方案
  7. JoyOI(TYVJ)1061-Mobile Service【线性dp】
  8. java8新特性(2)--接口的默认方法
  9. 方法 手写promise_手写Promise类
  10. php按条件修改xml,php 修改、增加xml结点属性的实现代码
  11. python的文件夹_Python文件夹与文件的操作
  12. Oracle技术之串行隔离对延迟段和INTERVAL分区的支持
  13. cartographer环境配置及运行
  14. 如何通过U盘等外部设备启动带有T2芯片的Mac?
  15. 超详细带你用Java实现QQ的聊天功能
  16. Java集合常见面试题集锦
  17. 设计物联网系统的步骤和原则有哪些
  18. 产品经理的进阶——需求的成长史
  19. 字节跳动 AI Lab 总监李航:语言模型的过去、现在和未来
  20. 3大类6种排序 插入排序 选择排序 冒泡排序 希尔排序 堆排序 快速排序 —————— 开开开山怪

热门文章

  1. python官网下载步骤手机-一招解决:各种版本的Python下载安装教程
  2. python在excel中的应用-Python利用pandas处理Excel数据的应用详解
  3. python基础知识资料-Python基础知识(一)—简介
  4. vscode使用教程python-VSCode下好用的Python插件及配置_python
  5. 怎么用python画简单的图-使用Python中的Turtle库绘制简单的图形
  6. python推荐系统-基于Python的推荐系统的设计与实现
  7. 快速记忆python函数-【速学速记】Python 列表生成式的进化:生成器
  8. 自学python该买几本书-自学Python一年,看了几十本书,我发现了这些捷径!
  9. python保留字的基本含义-python 33个保留字是什么意思
  10. python3.5怎么使用-在ros中使用python3.5