分享flex的Socket通讯沙箱和安全策略问题

一、沙箱和安全策略问题
    1、此问题发生在连接时,准确地说是连接前,分别两种情况:
        1.本地播放
       本地播放时,默认情况下Flash Player将不允许swf访问任何网络。
       访问http://www.macromedia.com/support/documentation/en/flashplayer/help/settings_manager04.html,将swf加入到许可列表,即可解除限制。
      2.WEB发布
       发布在WEB上的swf, 将可能面临跨域的问题。

    2、Flash中的通信方式有两种:
    1.HTTP方式:如URLLoader等用于加载远程swf、文件、图像、音视频流。
    2.Socket主要:如 XMLSocket,用于与远程服务端建立长效连接。
    Flash Player6以上版本引入了安全策略文件,在进行正式的通信前,会检查目标位置是否存在合法的安全策略,以防止不同域内的应用无限制任意互访。
    HTTP方式下,Flash Player会检查目标域根目录下是否存在crossdomain.xml,如果有,则获取并分析其内容(内容后述)以确定是否允许继续访问。
    Socket方式下,Flash Player获取安全策略稍微复杂些,从9.0.115.0版起,标准步骤如下(以下描述以IE为标准,例外情况后述):
     1)首先向目标主机 843 端口发起连接,并发送一个字符串,内容为"<policy-file-request/>",并等待返回安全策略文件并分析。
     2)若1)失败,则检查AS代码中是否使用了Security.loadPolicyFile("xmlsocket://主机:端口")方法加载安全策略文件,若有,则获取并分析。
     3)若2)失败,则向AS代码中即将连接的 "目标主机:端口" 发起请求,过程同1)。
     4)若成功获得安全策略文件并经分析认为允许建立连接,则继续执行Connect()方法,此时方真正尝试创建与目标主机的连接。

  3、解决方案
    HTTP 连接方式不用再说,只说说 Socket 方式。
    1) 在服务端写一个程序,监听843端口,当收到 "<policy-file-request/>" 时将恰当的策略内容(crossdomain.xml)发送回客户端。
    2) 在AS中通过loadPolicyFile()加载策略文件,此处需注意使用xmlsocket://,而不是 http://。
    3) 在标准服务端口中,检测到"<policy-file-request/>"时,返回策略内容。

  4、例外情况及测试结果
    经测试发现,在IE,Opera中,Flash Player会严格按上述步骤检查安全策略。
    在 FireFox, Chrome中发起连接时,Flash Player并不会向服务端发送"<policy-file-request/>",而是直接连接成功。这应该是Flash Player不同实现版本的原因。

    5、数据传输中的问题
     在XMLSocket数据传输中,需要注意以下细节,否则会出来些莫名其妙的问题。
       1.结束符号
     XMLSocket接收到服务端下发的数据时,将连续放于接收缓冲区,直到接收到""字节(字节内容为ASCII值0),才认为接收完成,并调用相应的onData或onXML事件。
     服务端若用Java编写,并使用标准的String类族,则在发送数据结尾应手动加上""。
     若用 C++ 编写,由于C++中标准字符串类型便是以字节0作结束标记,故不必再加""。
     * C++中需注意另一个问题,若自行进行了字符串处理,在决定字符串长度时,标准的strlen及String.Length()等返回的均是实际有效字符个数,最终向网络发送时,总长度应加1字节,以容纳结尾的字节0。
     * 此问题在发送安全策略内容时同样存在,故需重视。

       2.中文问题
     默认情况下,不管从哪一端发向另一端的数据,若包含了中文字符,都会产生乱码的现象,解决方法有二:
     1).在AS中加入"System.useCodepage=true;" 强制使用本地代码集,此法最方便,但是在跨语种平台上仍会出现乱码。
     2).在代码中自行编写转码函数,此法复杂些,但通用性强。具体转码算法网上很多,主要是C++服务端需要,Java中使用JDK类转换为UTF-8即可

时间: 2024-09-01 06:43:08

分享flex的Socket通讯沙箱和安全策略问题的相关文章

服务器-socket通讯方面的问题

问题描述 socket通讯方面的问题 Android用socket实现仿QQ功能时,必须要有文件服务器么?服务器用多个端口监听不行么? 还有socket只能同时发送一条信息么?可不可以用线程同时发送多条? 求好心人解决我的疑惑,谢谢 解决方案 java socket通讯乱码问题的解决flex的Socket通讯沙箱和安全策略问题Socket 通讯 接受到多条命令混合到一块问题 解决方案二: tcp是双工的,你只要持有那个socket对象,你可以用线程往这个socket里写东西,一个服务器一般都是监

flex web项目 安全沙箱冲突问题

问题描述 flex web项目 安全沙箱冲突问题 本人想通过flex页面调用客户端本地的一个socket实现智能提醒功能(该程序是客户端程序,非web项目),根据网上的资料,本人是在本地先测试的,然而还是报 "encounter security error:Error #2048: 安全沙箱冲突:http://localhost:8080/CommunityHealth/SocketTest.swf 不能从 127.0.0.1:5025 加载数据.",已经尝试了好几天了一直实现不了,

Silverlight下的Socket通讯

http://www.cnblogs.com/chengxingliang/archive/2012/05/24/2515100.html 在Silverlight中进行通讯,只能使用4502-4534之间的端口进行数据传输,另外Silverlight客户端会自动向943端口的服务器端发送一个"<policy-file-request/>"的语句请求,然后服务器端943端口回发以下文件以许可Socket通讯. <?xml version="1.0"

python中UDP方式实现socket通讯

Server: import socket address = ('127.0.0.1', 31500) s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) s.bind(address) while True: data, addr = s.recvfrom(2048) if not data: print "client has exist" break print "received:", data, &q

Unity3D实现基于Socket通讯的公共聊天室

多个客户端一同使用就是一个简单的公共聊天室.服务端为一个控制台程序使用C#实现,当然,在Unity3D中也相应地使用了C#语言实现客户端,服务端和客户端能实现消息的互通,当服务端接收到某客户端发送过来的消息时将会对客户端列表成员进行广播,这是公共聊天室的最基本的形式.Socket通讯是网络游戏最为基础的知识,因此这个实例能向有志投身于网游行业的初学者提供指导意义. using System; using System.Collections.Generic; using System.Linq;

Python Socket通讯程序例子

python中内置的socket模块使得网络编程更加简单化,下面就通过两个小小脚本来了解客户端如何与服务器端建立socket. 客户端代码: #clietn.py if __name__ == '__main__':  #判断是否调用自己本身,如果不是则__name__为脚本名称 import socket  #导入我们所需的socket模块sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)  #第一步是创建socket对象.调用so

python中TCP方式实现socket通讯

Server: # server import socket address = ('127.0.0.1', 31500) s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # s = socket.socket() s.bind(address) s.listen(5) ss, addr = s.accept() print 'got connected from',addr ss.send('byebye') ra = ss.recv

通信-pc机与android手机socket通讯的问题

问题描述 pc机与android手机socket通讯的问题 本人最近想做一个上微机在pc机上控制下位机(单片机)!同时这个上位机具有socket通信的功能能通过安卓手机远程控制上位机向单片机发送指令,现在pc机上的上位机做好了,然后使用winsocket服务端程序做好了!手机端安卓socket客户端!现在问题就是这两个socket之间好像不能通信啊!在电脑上使用java写的服务端可以和安卓手机通信! 我想问一下在电脑上用C语言和win api写的服务端有么有办法和安卓客户端的socket通信!有

试解析Tomcat运行原理(一)--- socket通讯(转)

关于这篇文章也确实筹划了很久,今天决定开篇写第一篇,说起tomcat首先很容易联想到IIS,因为我最开始使用的就是.net技术,我第一次使用asp写学生成绩管理系统后,很茫然如何让别人都能看到或者说使用这个系统呢?由此认识了IIS,它是一个web容器,天生的多线程,及时响应用户提交的请求返回html页面,这就是我了解的最初的web容器的功能,由此我们来认识tomcat也并不困难,可以的话,在了解完tomcat后我们可以继续了解jboss.jetty等,好我们进入主题. 我们在平时开发的过程中是在