Сервер Node.js не работает должным образом - PullRequest
0 голосов
/ 14 декабря 2011

Я пытаюсь сделать простой текстовый чат, например.Сервер запускается и работает.Мой клиент подключается нормально и в журнале консоли показывает:

C:\inetpub\wwwroot\3>node app.js
   info  - socket.io started
Socket-Chat listening on port 9202.. Go to http://<this-host>:9202
   debug - client authorized
   info  - handshake authorized 3088178251169496669
   debug - setting request GET /socket.io/1/flashsocket/3088178251169496669
   debug - set heartbeat interval for client 3088178251169496669
   debug - client authorized for
   debug - websocket writing 1::
   debug - websocket received data packet 3:::USERNAME:----------cvx
   debug - websocket received data packet 3:::xcvcx

Но не получают трансляцию для других клиентов чата.

Я пытаюсь вставить в разные части кода сервера вывод на консоль для тестирования, но он отображается только в некоторых местах (в коде «DISPLAY»), в других не отображается (в коде"НЕТ ДИСПЛЕЯ").Код сервера app.js:

var io = require('socket.io'),
  http = require('http');

var fs = require('fs'),
  util = require('util');

var url = require('url'),
  path = require('path'),
  mime = require('mime');

function findType(uri) {
  var ext = uri.match(/\.\w+$/gi);
  if (ext && ext.length > 0) {
    ext = ext[0].split(".")[1].toLowerCase();
    return mime.lookup(ext);
  }
  return undefined;
}

function sendError(code, response) {
  response.writeHead(code);
  response.end();
  return;
}
console.log("DISPLAY");
var app = http.createServer(function(request, response) {
  var uri = url.parse(request.url).pathname;
  console.log("NO DISPLAY");
  if (uri === '/') {
    uri = '/index.html';
  } else if (uri === '/app.js') {
    sendError(404, response);
    return;
  }
  var _file = path.join(process.cwd(), uri);
console.log("NO DISPLAY");
  path.exists(_file, function(exists) {
    if (!exists) {
      sendError(404, response);
    } else {
      fs.stat(_file, function(err, stat) {
        var file = __dirname + uri,
            type = findType(uri),
            size = stat.size;
        if (!type) {
          sendError(500, response);
        }
        response.writeHead(200, {'Content-Type':type, 'Content-Length':size});
        var rs = fs.createReadStream(file);
        console.log("NO DISPLAY");
        util.pump(rs, response, function(err) {
          if (err) {
            console.log("ReadStream, WriteStream error for util.pump");
            response.end();
          }
        });
      });
    }
  });

});

// Only listen on $ node app.js

if (!module.parent) {
  app.listen(9202);
  console.log("Socket-Chat listening on port 9202.. Go to http://<this-host>:9202");
}

var socket = io.listen(app, {transports:['websocket', 'flashsocket', 'xhr-polling']}),

  buffer = [],
  MAXBUF = 1024,
  json = JSON.stringify;

var clients = [];
clients.usernames = function(client) {
    console.log("NO DISPLAY");
  return client.username;
}

socket.on('connection', function(client) {
console.log("NO DISPLAY");

  client.on('message', function(data) {
    if ((/^(USERNAME:).*$/ig).test(data)) {
      var parts = data.split(":");
      var username = parts[1];

      if (!username || username == '') {
        client.send({announcement:"You must specify a username. Please reload the app."});
        return;
      }

      var usernames = clients.map(clients.usernames);
      if (usernames.indexOf(username) >= 0) {
        client.send({announcement:"Username in use"});
        return;
      }

      client.username = username;

      client.broadcast.json.send({announcement:client.username+' joined'});
      console.log(client.sessionId + " = " + client.username);
      client.send({messages:buffer});
      client.send({userlist:usernames});
      client.send({announcement:"Connected! Hello, " + username + "!"});

      clients.push(client);
      return;
    } 

    if (!client.username) {
      client.send({announcement:"You must specify a username. Please reload the app."});
      return;
    }

    var message = {'user':client.sessionId, 'username':client.username, 'message':data};
    buffer.push(message);
    if (buffer.length > MAXBUF) {
      buffer.shift();
    }
    client.broadcast.json.send(message);
  });

  client.on('disconnect', function() {
    if (client.username) {
      client.broadcast({announcement:(client.username)+' left chat'});
    }
    var pos = clients.indexOf(client);
    if (pos >= 0) {
      clients.splice(pos, 1);
    }
  });
});

Подскажите возможные причины этой проблемы, пожалуйста.Сервер установлен на Windows 7 (IIS7)

1 Ответ

1 голос
/ 21 декабря 2011

Я ответил на несколько похожих вопросов, касающихся socket.io, пытаясь избежать копирования и вставки одного и того же материала :) - cf info - unhandled socket.io url

По существу, в API произошли незначительные изменения, попробуйте изменить socket.on('connection' на socket.sockets.on('connection'

Надеюсь, это поможет.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...