文章来之:http://blog.zol.com.cn/790/article_789021.html
so的工作原理是,任何地方修改了so,都会马上同步到所有共享(share)此对象(object)的节点,不管是客户端还是服务器。这就带来了两个问题,第一,大家都知道用户的提交是不可信的,未经验证的东西同步到所有共享此对象的节点,其危险性不言而喻;第二,flash是由访问者下载到本地运行的,而且半编译半解释的脚本语言属性令其破解相对别的客户端而言容易了许多,所以不排除会有些人破解客户端然后用hack的客户端达成某种不可告人的目的。
另外一个危险的地方体现在隐私保护上。如果用so实现私聊的话,或者每次都建立一个so,或者在so里面增加toid的标记,但后者有一个问题就是聊天内容始终是向所有连接到此so的用户广播的,因此如果有人怀着不良动机hack了客户端,那么是有可能监听到别人的聊天内容,这也是无法容忍的。
于是有人提出不要使用so,老老实实用客户端调用服务器方法,服务器端再回调目标客户端。不过我觉得这种做法未免太消极,毕竟在多客户端的时候,so无论从时间上海市空间上都要好于方法直通——不然干嘛要做这个东西出来——因此完全可以想其他的方法来保全。
然后稍微写下我的想法。首先,用调用服务器端方法来发言,同时将so设为只读,只能在服务器端修改。调用方法有很严格的变量类型限制,可以用作规范;而在服务器端修改so,又能很方便的同步到其它机器上,问题就解决了。
第二,在页面当中插入聊天flash时增加类似验证码的操作,同时利用跨域策略文件限制,降低其他人使用恶意hack修改过的客户端的可能性。
第三,依照测试的经验,N人以下的会话使用命令直连;N人以上的会话使用so同步,来平均服务器消耗。
就写到这儿吧,继续去调程序了~~~
分享到:
相关推荐
- **概念解析**:SharedObject是Red5中用于存储跨连接会话数据的机制,能够在不同用户间共享信息,适用于游戏中的移动同步等场景。 - **移动同步原理**:通过SharedObject,游戏中的玩家移动和其他动态信息能够实时...
Red5还支持共享对象(SharedObject),这是一种在客户端和服务器之间共享数据的机制,类似于Web浏览器中的cookie,但具有更大的存储容量和更低的延迟。 在“基于red5的多人聊天”项目中,SharedObject起到了关键...
1. 安装Red5:首先从Red5官方网站下载最新版本的Red5服务器,解压到合适的目录,配置相关的环境变量,确保Java环境已经安装并且版本兼容。 2. 安装Tomcat:从Apache Tomcat官网获取Tomcat的安装包,按照指南进行...
【Red5 开发详解】 Red5 是一款基于 Java 开发的开源流媒体服务器,与 Adobe 的 Flash Media Server (FMS) 类似,提供多种功能,包括流媒体传输、录制、共享对象、远程调用等。它支持RTSP协议,允许在下载过程中...
5. **互动性**:Red5 Server支持与客户端的双向通信,例如通过Flash的SharedObject实现聊天室功能,或者进行游戏交互等。 6. **Java平台**:Red5 Server是用Java语言编写的,这意味着它可以在任何支持Java的平台上...
例如,`red5-common.xml` 中的 JMX(Java Management Extensions)配置可能需要根据实际需求或安全策略来决定是否启用。在这个例子中,JMX 服务器的相关配置(`jmxFactory` 和 `jmxAgent`)被注释掉,因为它们可能...
`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. **SOSampleDemo**:SOSample是一个示例应用,展示了如何使用Red5的SharedObject服务。SharedObject是Flash中的一个特性,类似于Web存储,允许在客户端和服务器之间共享数据。SOSample可以帮助开发者理解如何在Red...
【Red5入门教程】 Red5是一款基于Java开发的开源免费Flash流媒体服务器,与Adobe的FMS(Flash Media Server)类似,提供了丰富的功能,包括实时流传输、录制、共享对象、远程调用以及视频播放与录制等。由于其开源...
### Flex Java Red5 完全学习手册核心知识点详解 #### 一、Red5介绍与安装 **Red5介绍** Red5是一款基于Java开发的开源免费的Flash流媒体服务器,其功能与Adobe Flash Media Server (FMS) 类似,可以在官方网站 ...
9. **安全设置**:为了保护流媒体内容,Red5支持基本的认证和授权机制。可以设置访问控制,限制特定用户或IP的访问权限。 10. **扩展与插件**:Red5的开源性质意味着社区提供了许多插件和扩展,如视频转码、多播...
Red5是一款开源的流媒体服务器,它允许开发者创建实时的、交互式的富因特网应用程序(Rich Internet Applications,简称RIA)。0.9.1是Red5的一个特定版本,旨在提供稳定性和性能改进,以及可能的新功能。在这个版本...
Red5是一款开源的流媒体服务器,它支持实时流传输协议(RTMP)、RTMPT、RTMPE、RTMPS以及HLS等协议,能够处理音视频数据的录制、播放和存储。在Web开发中,尤其是涉及到在线直播、互动聊天等应用场景时,Red5是一个...
6. **安全与性能**:讨论RED5的安全设置,如访问控制、加密传输,以及优化服务器性能的方法。 7. **故障排查与日志分析**:提供解决常见问题的步骤,以及如何分析服务器日志来定位和解决问题。 8. **实例应用**:...
Red5是一款基于Java的开源Flash流媒体服务器,它支持RSTP协议,提供了一系列示例应用,如在线录制、播放、聊天和视频会议等。Red5作为Macromedia商业产品FMS的一个替代方案,具有开源、成本低和可扩展性强的优势。在...
Red5 1.0 Final是该软件的一个稳定版本,为用户提供了一个可靠的平台来处理多媒体数据。 在整合Red5 1.0 Final与Apache Tomcat时,我们首先要理解这两个组件的角色。Red5作为一个流媒体服务器,负责处理和分发...
标题中的“在eclipse中使用tomcat开发RED5项目”是指使用流行的Java集成开发环境Eclipse,配合开源的Servlet容器Tomcat,来搭建并开发RED5流媒体服务器项目。RED5是一个基于Java语言的开放源代码流媒体服务器,能够...
添加Red5服务器的jar包到工程中,包括C:\Program Files\Red5\red5.jar和C:\Program Files\Red5\lib目录下的所有jar文件。 3. **编写服务器端代码**: 在src目录下创建first包,然后在first包内创建Application类...