提问人:Simon 提问时间:11/11/2009 最后编辑:Simon 更新时间:12/8/2009 访问量:5337
为什么 Flash Player 在这种情况下会抛出沙盒错误?
Why does the Flash Player throw a sandbox error in this case?
问:
连接到 Java (1.5) 服务器上的套接字后,我收到 Flex 3 沙盒错误 #2048。服务器代码都是我的,即不在Apache下运行。Flash Player 10.0 版本32。
顺序如下...
1 Java 服务器启动,在端口 843 上侦听策略文件请求,在端口 45455 上侦听我的其他请求。
2 Apache提供的Flex客户端(尽管如果我从文件系统运行它,我会得到相同的结果),套接字连接在host:45455上建立。
3 Flash Player 从端口 843 请求策略文件。这是查找主文件的新安全设置的标准行为。无论是否指定了其他策略文件,都会发生这种情况。
4 我通过端口 843 从 Java 提供以下 XML:
<?xml version="1.0"?>
<!DOCTYPE cross-domain-policy SYSTEM "http://www.macromedia.com/xml/dtds/cross-domain-policy.dtd">
<cross-domain-policy>
<site-control permitted-cross-domain-policies="all"/>
<allow-access-from domain="*" to-ports="*" secure="false"/>
</cross-domain-policy>
5 播放器将以下内容写入调试策略日志...
OK: Root-level SWF loaded: http://localhost/bst/BasicSocketTest.swf
OK: Searching for <allow-access-from> in policy files to authorize data loading from resource at xmlsocket://192.168.2.3:45455 by requestor from http://localhost/bst/BasicSocketTest.swf
OK: Policy file accepted: xmlsocket://192.168.2.3:843
OK: Request for resource at xmlsocket://192.168.2.3:45455 by requestor from http://localhost/bst/BasicSocketTest.swf is permitted due to policy file at xmlsocket://192.168.2.3:843
6 我使用 和 从客户端向端口 45455 上的服务器发送一条短信(这是我自己烘焙的消息协议,并且在每一端都正确处理)writeUTFBytes()
flush()
REG/REGISTER;simon;Si
7 侦听端口 45455 的 Java 服务器线程响应
REG:0/REGISTER:SUCCESS;simon;Si
8 Flex 客户端接收到 ProgressEvent,并调用我绑定到套接字的事件侦听器。我处理消息(将其写入屏幕上的文本框)
9 Flash 播放器抛出 2048 沙盒错误,套接字断开连接!这是在成功接收和处理消息之后。事实上,它大约是 12 秒后。没有其他东西可以通过插座工作。
我尝试在 Flex 客户端中显式加载带有调用的策略文件,但新播放器安全性的现实是它基本上被忽略了。步骤是,在发生套接字 I/O 操作之前,不会发送策略请求。此时,玩家总是首先转到端口 843 寻找主策略文件。如果它找到了一个,而且它是宽容的,它就不会再进一步了。Security.loadPolicyFile()
我尝试了各种终止策略文件和策略文件内容的替代方法,包括故意出错只是为了查看 Flash Player 是否处于唤醒状态。
我看不出为什么我会扔一个 2048。我准确地在指定的主安全端口上提供套接字策略文件,播放器本身将其记录为正确。然后,套接字成功发送和接收来自服务器的消息,其内容可供我的代码使用。
有没有人知道为什么会发生这种情况?Flash Player 错误?
P.S. 请不要告诉我使用 BlazeDS 或 LCDS 或 Granite 或其他东西作为服务器,我正在寻找解决这个问题的方法,而不是重新设计。请不要要求我改用 XMLSocket - 我试过了,得到了完全相同的结果。我仔细而深思熟虑地选择了我的架构,我想要一个二进制套接字。
编辑为了回应詹姆斯·沃德(James Ward)在评论中的请求,以下是整个错误消息:
Error #2048: Security sandbox violation: http://localhost/bst/BasicSocketTest.swf cannot load data from 192.168.2.3:45455.
我有一个精简的测试客户端,它有一个用于每个套接字事件的处理程序,并将一条消息输出到屏幕。这是它显示的内容:
RequestPolicy: 192.168.2.3:843
Create Socket: 192.168.2.3:45455
Connect: [Event type="connect" bubbles=false cancelable=false eventPhase=2]
Sending: REG/REGISTER;[email protected];Si
Receiving: REG:0/REGISTER:SUCCESS;[email protected];Si/
Close: [Event type="close" bubbles=false cancelable=false eventPhase=2]
Error #2048: Security sandbox violation: http://localhost/bst/BasicSocketTest.swf cannot load data from 192.168.2.3:45455.
成功收到来自服务器的响应后,会立即触发关闭事件,但错误 #2048 直到大约 20 秒后才会出现。如果我尝试在关闭后但在错误之前发送另一条消息,Flash Player 将引发无效套接字异常。
我在Adobe上记录了一个关于此的错误。
如果有人感兴趣,我可以提供客户端和服务器的完整源代码。
答:
此处的类似问题表明 localhost 未解析为 127.0.0.1。
您可以尝试切换到 IP 地址,看看是否有帮助。
评论
除了 yoru 之外,您还可以使用 Security 类在代码中进一步尝试一些操作crossdomain.xml
尝试:
Security.allowDomain("*")
Security.allowInsecureDomain("*")
或者,如果您从允许的主机外部的外部服务器加载:
Security.allowDomain(loader.contentLoaderInfo.url)
然后慢慢重新打开它,直到你遇到错误。
确保您可以直接点击策略文件,并且该端口上没有运行任何块或其他应用程序。通常,当我运行套接字时,我会高于 5000,以确保没有任何东西会占用端口。或者尝试几个不同的端口。
此外,就像一个简单的检查一样,请确保您将其命名为crossdomain.xml并且都是小写的。我曾让程序员拔掉头发,结果证明这就是原因。
评论
您是否尝试过添加allow-http-request-headers-from元素?
<allow-http-request-headers-from domain="*" headers="*" />
或者为 allow-access-from 元素指定实际端口而不是 *?
<allow-access-from domain="*" to-ports="843,45455" />
评论
尝试在 xml 结束标记“/>”之前留空,就像dan_nl建议一样,例如:
<allow-access-from 域=“*” />
不要嘲笑它,我刚刚解决了一个与你非常相似的问题(恕我直言,它看起来真的像一个解析错误)
无论如何......这是否发生在 Windows Vista 上?是否将 IP 地址指定为主机名?如果是这样,请看这个。
或者它可能是在探查器处于活动状态时发生的?如果是这样,请看这个。
评论
发送策略文件时,服务器应始终在策略 xml 后发送零字节。从上面的描述中不清楚是否发送了零字节,这最终可能会混淆 Flash 播放器。
评论
这可能会也可能不会对您有所帮助,但我们遇到了类似的问题。我们收到安全错误,但不一致。我构建了前端,并与一位开发人员合作,他正在处理用 PHP 编写的 Socket。问题似乎在于确实存在争用条件,即 Flash 会在收到策略文件之前尝试连接到套接字。因此,在前端,我在安全错误处理程序中创建了一个重试,该处理程序将在放弃之前运行设定的次数,还将超时从默认的 20 秒设置为 6 或 8。它通常会在第二次尝试时流行起来,这确实有所帮助,但有时需要 8-10 秒才能连接,这不是最佳解决方案。
在我的搜索中遇到了一些链接,这个链接说了一些关于在服务器上设置延迟的内容,第 7 个帖子下来:http://projectdarkstar.com/forum/?action=printpage;topic=1134.0
最后,我们从这篇 Adobe 文章中下载并使用了 Python 策略文件服务器,它一直完美无缺地工作,我无法解释为什么,我不是服务器人员,但可能值得一试:
好吧,我只能发布 1 个超链接,因为我是新用户,很奇怪。搜索“设置套接字策略文件服务器”,它应该会出现,Adobe 网站上的那篇文章中有示例文件。
评论
我一直在本地测试它,在套接字关闭之前一切似乎都正常工作。插座不应该关闭吗?将消息发送到 Flex 客户端后,Java 代码将执行以下操作:
_in.close();
_out.close();
_socket.close();
然后,Flex 客户端在下次尝试与套接字通信时会收到沙盒冲突。如果我再次创建一个新的套接字连接,那么发送和接收工作正常,然后关闭。但是大约一分钟后,我又遇到了另一个沙盒违规。我想知道 Flash 是否正在尝试 ping 套接字并且由于它已关闭,它抛出了沙盒违规?
评论
close
我认为 James Ward 是对的——我现在正在使用 Sockets,前几天我遇到了这个问题。我发现了一个帖子,建议如果 Flash 客户端在调度 COMPLETE 事件时没有关闭套接字,这可能会导致您看到的错误。我已经添加了代码以在 COMPLETE 上关闭客户端套接字,到目前为止一切正常。
评论