FLEX SharedObject介绍及应用
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介绍及应用相关推荐
- 2.React Native Flex布局介绍以及实践
好久没有写博客,一直在用自己的印象笔记记录一些问题.2017年了,想重新的把博客写起来.也希望通过这个平台交一些朋友. 没有具体的介绍基本的语法,主要是说明了与标准的CSS Flex的一些区别以及一个 ...
- 最简单的flex布局介绍(转自阮一峰)及筛子案例
大佬阮一峰在15年的博客至今我认为无人可以超越 所以就直接引用他的博客 Flex 布局教程:语法篇 - 阮一峰的网络日志 (ruanyifeng.com) 在引用之后为一个flex布局小demo Fl ...
- 微信小程序布局display flex布局介绍
display flex是什么? 微信小程序最近火的不要不要的,下载开发工具测试了一下,小程序对css支持很好, 布局使用display flex布局火力强大,不太了解或者对flex布局比较生疏的童靴 ...
- Flash本地共享对象 SharedObject
以下内容是对网上一些资料的总结 Flex SharedObject 介绍(转自http://www.eb163.com/club/thread-3235-1-1.html): Flash的本地共享对象 ...
- JavaScript 5/30:Flex Panel Gallery即FLEX布局的图片库
JavaScript30 为Wes Bos推出的一项为期30天的挑战,旨在帮助人们用纯JavaScript来实现效果,初学者若想在JS方面快速精进,不妨一试.本题为第五题. 实现效果 点击任意一张图片 ...
- Flex与.NET互操作(十六):FluorineFx + Flex视频聊天室案例开发
本文将使用FluorineFx和Flex结合介绍一个简单的视频聊天室案例开发,希望通过此篇和大家交流FluorineFx和Flex的相关技术,同时也希望本篇可以帮助到需要使用FluorineFx做及时 ...
- image 微信小程序flex_微信小程序进阶-flex布局
对于一个后端程序员来说最麻烦的就是布局了,今天就介绍下小程序的布局,介绍一种高效的小程序布局方案.笔者之前也做过native app的布局,对比下来,小程序的布局没有native那么灵活,毕竟goog ...
- 你不能只会flex居中布局,精制动画讲解所有flex布局方式,通俗易懂教程
flex布局相信很多人都已经有不少了解,其优势和作用被越来越多的开发者所喜爱,网上也有很多关于关于flex的介绍和教程.但是根据笔者的面试经验发现,很多人尤其是初中级开发者对flex布局都仅仅停留下c ...
- CSS中flex的用法( 学习笔记 )
flex( 弹性盒.伸缩盒 ) flex 的介绍 flex是CSS中的又一种布局手段,它主要用来代替浮动来完成页面的布局 flex可以使元素具有弹性,让元素可以随页面的大小的改变而改变 弹性容器 要使 ...
最新文章
- c语言包括在方括号中的序号称为,自考《高级语言程序设计》知识点总结(四)...
- 零基础自学python的建议-关于零基础学习 Python 有什么好的建议?
- angularJS(5)
- Spring mvc ContextLoaderListener 原理解析
- C++内部类访问外部类
- Crontab中shell每分钟执行一次HDFS文件上传不执行的解决方案
- JoyOI(TYVJ)1061-Mobile Service【线性dp】
- java8新特性(2)--接口的默认方法
- 方法 手写promise_手写Promise类
- php按条件修改xml,php 修改、增加xml结点属性的实现代码
- python的文件夹_Python文件夹与文件的操作
- Oracle技术之串行隔离对延迟段和INTERVAL分区的支持
- cartographer环境配置及运行
- 如何通过U盘等外部设备启动带有T2芯片的Mac?
- 超详细带你用Java实现QQ的聊天功能
- Java集合常见面试题集锦
- 设计物联网系统的步骤和原则有哪些
- 产品经理的进阶——需求的成长史
- 字节跳动 AI Lab 总监李航:语言模型的过去、现在和未来
- 3大类6种排序 插入排序 选择排序 冒泡排序 希尔排序 堆排序 快速排序 —————— 开开开山怪
热门文章
- python官网下载步骤手机-一招解决:各种版本的Python下载安装教程
- python在excel中的应用-Python利用pandas处理Excel数据的应用详解
- python基础知识资料-Python基础知识(一)—简介
- vscode使用教程python-VSCode下好用的Python插件及配置_python
- 怎么用python画简单的图-使用Python中的Turtle库绘制简单的图形
- python推荐系统-基于Python的推荐系统的设计与实现
- 快速记忆python函数-【速学速记】Python 列表生成式的进化:生成器
- 自学python该买几本书-自学Python一年,看了几十本书,我发现了这些捷径!
- python保留字的基本含义-python 33个保留字是什么意思
- python3.5怎么使用-在ros中使用python3.5