我在node.js中有一个简单的基于socket.io的服务器,它监听端口81中的套接字(例如)
我在用 Javascript 编写的客户端之间连接和传递数据没有问题
但经过多次尝试后,我无法让我的 Flash 应用程序连接到服务器并向其传递数据
(我在网上找到了一些示例 - 但它们都是基于 Flex 的,并且使用的类不属于基本 AS3 库的一部分)
当我尝试使用 XMLSocket 连接到套接字时 - 我收到安全沙箱违规错误 - 我知道我需要加载策略文件(假设可以使用 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>
非常感谢您的宝贵时间!