2012-11-28 2 views
5

Sto creando un'applicazione di chat, utilizzando nodejs (0.8.15), express (> 3.0) framework e mongodb per gli utenti registrati.nodejs, socket.io: come ottenere la richiesta e la risposta dalla funzione socket?

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

var app = express() 
    , server = http.createServer(app) 
    , io = io.listen(server); 

    app.configure(function() { 
     app.set('port', process.env.PORT || 3000); 
     app.set('views', __dirname + '/views'); 
     app.set('view engine', 'ejs'); 
     app.use(express.favicon()); 
     app.use(express.logger('dev')); 
     app.use(express.bodyParser()); 
     app.use(express.methodOverride()); 
     app.use(express.cookieParser('secret')); 
     app.use(express.session({cookie: {maxAge: 60000*100}})); 
     app.use(app.router); 
     app.use(express.static(path.join(__dirname, 'public'))); 
    }); 

    app.configure('development', function() { 
     app.use(express.errorHandler()); 
    }); 

    app.get('/chat', function(req, res) { 
     res.render('chat'); 
    }); 

server.listen(app.get('port'), function() { 
    console.log("Express server listening on port " + app.get('port')); 
    }); 

io.sockets.on('connection', function (socket) { 
    socket.on('start-chat', function() { 
     // here i need to know req and res 
     // for example, i need to write: 
     // socket.username = req.session.username; 
    }); 
}); 

Q: Come ottenere res e oggetti req per lavorare con loro quando chattare come sopra nel codice? o sto sbagliando il modo di creare chat con l'autenticazione dell'utente?

grazie!

CURA: risposta è qui http://www.danielbaulig.de/socket-ioexpress/

risposta

4

Non è possibile ottenere res e oggetti req in un gestore socket.io, in quanto semplicemente non esistono - socket.io non è normale http.

Invece, ciò che puoi fare è autenticare gli utenti e assegnare loro un token di autenticazione di sessione (una chiave che identifica che sono loggati e chi sono). Poi il cliente può inviare il token di autenticazione con ogni messaggio socket.io, e il gestore lato server può solo verificare la validità della chiave nel database:

3

è necessario utilizzare authorization.

var socketIO = require('socket.io').listen(port); 
socketIO.set('authorization', function(handshakeData, cb) { 
    //use handshakeData to authorize this connection 
    //Node.js style "cb". ie: if auth is not successful, then cb('Not Successful'); 
    //else cb(null, true); //2nd param "true" matters, i guess!! 
}); 

socketIO.on('connection', function (socket) { 
    //do your usual stuff here 
}); 
-1

su socket.io v1.0 e, soprattutto, si può ottenere l'oggetto req come questo

var req = socket.request; 
var res = req.res; 
+0

Questo è sbagliato. Questa non è la stessa richiesta che viene posta in questione. Non troverai il tuo parametro di richiesta sopra socket.request. –