1

これが私のサーバーです

var io = require('socket.io').listen(80);

io.sockets.on('connection', function (socket) {
  socket.emit('news', { hello: 'world' });
  socket.on('my other event', function (data) {
    console.log(data);
  });
});

ここに私のクライアントindex.htmlがあります

<script src="/socket.io/socket.io.js"></script>
<script>
  var socket = io.connect('http://localhost:80');
  socket.on('news', function (data) {
    console.log(data);
    socket.emit('my other event', { my: 'data' });
  });
</script>

これが私のコマンドです

node server.js

ブラウザでURLにアクセスしていますlocalhost:80/index.html

上記の URL にアクセスすると、メッセージ Welcome to socket.io. が表示されます。

私はnodeJS v0.10.9を使用しています

4

1 に答える 1

2

socket.iosocket.ioWeb サーバーではなく、サーバーを提供します。したがってindex.html、のコンテキストでsocket.ioは存在しません。

代わりに、Expressを使用して基本的な Web サーバーを提供し、 と組み合わせてsocket.ioメッセージングを提供できます。

// server.js
var express = require('express');
var app     = express();
var server  = require('http').createServer(app);
var io      = require('socket.io').listen(server);

io.sockets.on('connection', function (socket) {
  socket.emit('news', { hello: 'world' });
  socket.on('my other event', function (data) {
    console.log(data);
  });
});

app.use(express.static(__dirname + '/public'));

server.listen(80);
// ./public/index.html
<!doctype html>
<html>
  <head>
    <script src="/socket.io/socket.io.js"></script>
    <script>
      var socket = io.connect(); // let socket.io autodiscover the server
      socket.on('news', function (data) {
        console.log(data);
        socket.emit('my other event', { my: 'data' });
      });
    </script>
  </head>
  <body>
    <h1>Hello World</h1>
  </body>
</html>
于 2013-06-05T13:09:54.460 に答える