SOに関するこのトピックについていくつかの議論があったことは知っていますが、私の質問に対する答えが見つかりません。localhost:8020 で Aptana を使用してサーバー上で Web ページを実行しています。ページの JavaScript が、localhost:1337 で実行しているノード サーバーにアクセスしています。ノードコードは次のとおりです。
var io = require('socket.io');
var http = require('http');
var sys = require('sys');
var json = [];
var server = http.createServer(function (req, res) {
var headers = {};
headers["Access-Control-Allow-Origin"] = "*";
headers["Access-Control-Allow-Methods"] = "POST, GET, PUT, DELETE, OPTIONS";
headers["Access-Control-Allow-Credentials"] = true;
headers["Access-Control-Max-Age"] = '86400'; // 24 hours
headers["Access-Control-Allow-Headers"] = "X-Requested-With, Access-Control-Allow-Origin, X-HTTP-Method-Override, Content-Type, Authorization, Accept";
res.writeHead(200, headers);
res.end();
});
server.listen(1337, '127.0.0.1');
console.log('Server running at http://127.0.0.1:1337/');
var socket = io.listen(server);
socket.on('connection', function(){
console.log("Connected");
});
私は常にヘッダーを変更してcorsリクエストを処理しています。私のクライアント側のコードは通常、socket.io の初心者向けのものです。これが私のコードのタグです:
<script src="http://cdn.socket.io/stable/socket.io.js"></script>
<script>
// Create SocketIO instance
var socket = new io.Socket('localhost',{
port: 1337
});
socket.connect();
// Add a connect listener
socket.on('connect',function() {
log('<span style="color:green;">Client has connected to the server!</span>');
});
// Add a connect listener
socket.on('message',function(data) {
log('Received a message from the server: ' + data);
});
// Add a disconnect listener
socket.on('disconnect',function() {
log('<span style="color:red;">The client has disconnected!</span>');
});
// Sends a message to the server via sockets
function sendMessageToServer(message) {
socket.send(message);
log('<span style="color:#888">Sending "' + message + '" to the server!</span>');
}
// Outputs to console and list
function log(message) {
var li = document.createElement('li');
li.innerHTML = message;
document.getElementById('message-list').appendChild(li);
}
コードを実行すると、「XMLHTTPRequest...Origin is not allowed by Access-Control-Allow-Origin」エラーが発生し続けます。私のブラウザはクロムです。1. ブラウザが Websocket ではなく XMLHTTPRequest を使用しているのはなぜですか? 2. ヘッダーを変更しているときにアクセス制御エラーが発生するのはなぜですか? 事前にご協力いただきありがとうございます。