多分これはあなたにも役立つかもしれません。socket.ioがどのように機能するか頭を悩ませるのに苦労していたので、できる限りサンプルを煮詰めようとしました。
私はここに投稿された例からこの例を採用しました:http : //socket.io/get-started/chat/
まず、空のディレクトリから始めて、package.jsonという非常に単純なファイルを作成します。その中に以下を配置します。
{
"dependencies": {}
}
次に、コマンドラインでnpmを使用して、この例に必要な依存関係をインストールします
$ npm install --save express socket.io
ネットワーク接続/ CPUなどの速度によっては、この処理に数分かかる場合があります。すべてが計画どおりに進んだことを確認するには、package.jsonファイルをもう一度確認します。
$ cat package.json
{
"dependencies": {
"express": "~4.9.8",
"socket.io": "~1.1.0"
}
}
server.jsというファイルを作成します。 これは明らかにノードによって実行されるサーバーです。その中に次のコードを配置します。
var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http);
app.get('/', function(req, res){
//send the index.html file for all requests
res.sendFile(__dirname + '/index.html');
});
http.listen(3001, function(){
console.log('listening on *:3001');
});
//for testing, we're just going to send data to the client every second
setInterval( function() {
/*
our message we want to send to the client: in this case it's just a random
number that we generate on the server
*/
var msg = Math.random();
io.emit('message', msg);
console.log (msg);
}, 1000);
index.htmlという最後のファイルを作成し、次のコードをその中に配置します。
<html>
<head></head>
<body>
<div id="message"></div>
<script src="/socket.io/socket.io.js"></script>
<script>
var socket = io();
socket.on('message', function(msg){
console.log(msg);
document.getElementById("message").innerHTML = msg;
});
</script>
</body>
</html>
これで、この非常に単純な例をテストして、次のような出力を確認できます。
$ node server.js
listening on *:3001
0.9575486415997148
0.7801907607354224
0.665313188219443
0.8101786421611905
0.890920243691653
Webブラウザーを開いて、ノードプロセスを実行しているホスト名をポイントすると、ブラウザーに同じ番号が表示され、同じページを閲覧している他の接続されたブラウザーも表示されます。