5

我在 node.js 中有一个简单的基于 socket.io 的服务器,它监听端口 81 中的套接字(例如)我在用 Javascript 编写的客户端之间连接和传递数据没有问题但是经过多次尝试后我无法得到我的Flash 应用程序连接到服务器并将数据传递给它(我在网络上找到了一些示例 - 但所有这些示例都是基于 flex 的,并且使用不属于基本 AS3 库的类)

当我尝试使用 XMLSocket 连接到套接字时 - 我收到 Security Sandbox Violation Error - 我知道我需要加载策略文件(假设可以使用 socket.io)但我无法做到它

这是我的闪存代码:

Security.loadPolicyFile("http://127.0.0.1:81/crossdomain.xml");
socket = new XMLSocket("127.0.0.1", 81);
socket.addEventListener(Event.CONNECT, onConnect);  
socket.addEventListener(IOErrorEvent.IO_ERROR, onError);  
socket.addEventListener(SecurityErrorEvent.SECURITY_ERROR, onSecurityEvent);
socket.addEventListener(DataEvent.DATA, onData);

服务器端代码是

var app = require('http').createServer(function (req, res) {...})
   , io = require('socket.io').listen(app, { log: true })
   , fs = require('fs')

app.listen(81);

io.sockets.on('connection', function (socket) {
    console.log("connection "+socket.id);
    socket.on("message",function(data){
        console.log("data: "+data);
    });
    socket.on("data",function(d){
         console.log('data from flash: ',d);
    });
    socket.on('disconnect', function (socket) {
        console.log("disconnect");
    });
});

我的 crossdomain.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="master-only"/>
    <allow-access-from domain="*" to-ports="*"/>
</cross-domain-policy>

非常感谢您的宝贵时间!

4

2 回答 2

4

在我们的上一个项目中,我们使用了 FlashSocket.IO,它的工作就像一个魅力。

我们必须在服务器端做一些小的调整(即确保 socket.io 监听端口 843 而不是 10843 上的策略文件)并激活 flashsocket 传输,但通信很轻松。

io.configure(function() {
  io.set('transports', ['websocket','flashsocket']);
  io.set('flash policy port', 843);
});

注意:此配置要求 node.js 以 root 身份运行!

于 2013-01-17T08:43:55.260 回答
0

试试这个解决方案(除了843端口上的游戏服务器,你还需要设置套接字策略服务器)

顺便说一句:当您使用套接字时,请始终使用类似 url xmlsocket://host:port(对于端口 843 闪存自动加载策略文件),而不是http://host:port仅用于 http 请求。

于 2013-01-17T06:57:17.617 回答