4

これらのnodejsとsocket.ioをインストールしましたが、クライアントをサーバーに接続する際に問題が発生します。

私のサーバーには次のものがあります。

var http = require('http');
http.createServer(function (req, res) {
  res.writeHead(200, {'Content-Type': 'text/plain'});
  res.end('Hello World\n');
}).listen(3000, 'localhost');
console.log('Server running at http://localhost:3000/');

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

io.sockets.on('connection', function (socket) {

  socket.emit('Hi.') ;

});

そして私のクライアントでは:

<script src="/socket.io/socket.io.js"></script>
<script>
var socket = io.connect('http://localhost:3000');

socket.on('connect', function () {
  socket.emit('set nickname', confirm('What is your nickname?'));
  socket.on('ready', function () {
    console.log('Connected !');
    socket.emit('msg', confirm('What is your message?'));
  });
});

Chromeインスペクターでいくつかのエラーが発生します:

GET http://localhost:9261/socket.io/socket.io.js 404 (Not Found)
Uncaught ReferenceError: io is not defined
4

6 に答える 6

2

クライアントコードを含むhtmlではなく、「Hello World」のみをクライアントに送信しているようです。

サーバーコードは次のようになります ( http://socket.io/#how-to-useから):

var app = require('http').createServer(handler)
  , io = require('socket.io').listen(app)
  , fs = require('fs')

app.listen(80);

function handler (req, res) {
  fs.readFile(__dirname + '/index.html',
  function (err, data) {
    if (err) {
      res.writeHead(500);
      return res.end('Error loading index.html');
    }

    res.writeHead(200);
    res.end(data);
  });
}

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

クライアント コードは にあるはずですindex.htmlsocket.ioまた、スクリプトを含む名前のフォルダーがあることを確認してくださいsocket.io.js

于 2012-04-09T12:01:32.360 に答える
2

nodeJS経由でクライアントにサービスを提供していない場合、これは機能しません:

<script src="/socket.io/socket.io.js"></script>

代わりにこれを使用してみてください:

<script src="http://localhost:3000/socket.io/socket.io.js"></script>
于 2012-04-09T14:04:37.607 に答える
1

クライアントがsocket.io.jsを見つけることができないため、接続できません。適切なファイルを使用して解決できます。node_modules\ socket.io \ node_modules \ socket.io-client\distディレクトリからsocket.io.jsを使用してください。それをローカルディレクトリに置き、スクリプトタグで使用します。

于 2012-12-13T13:42:29.230 に答える
0

これはio、適切にインスタンス化されていない可能性が高いため、 Uncaught ReferenceError: io が定義されていません

// Instantiate without argument
var io = require('socket.io')();
// Instantiate with new keyword
var Server = require('socket.io')
  , io = new Server();

// Instantiate io server with app as argument
var app = require('http').createServer(handlerFunc)
  , io = require('socket.io')(app);
app.listen(80);

// Attaching socket.io with express server
var app = express()
  , server = require('http').createServer(app)
  , io = require('socket.io')(server);
server.listen(80, handlerFunc);
于 2014-12-07T07:40:03.557 に答える
0

また、本番環境に移行するときは、クライアントのコードを更新する必要があることに注意してください。

var socket = io.connect('http://localhost:3000');

のようなものに

var socket = io.connect('my_host');

パラメータを抽出して、my_host読み込み中のページを含むクライアント側スクリプトに送信したので、次のようになります。socket.ioreq.headers.host

 io.connect('http://' + host)

を通じて、クライアント側で変数を公開できますexpress-expose

于 2014-02-22T13:56:53.170 に答える