6

ゴール

私がしたいこと:

  • ユーザーのセッションを作成する
  • ソケットのセッションを作成します ( socket.io)
  • ログインとセッションpassport.jsの認証に使用します。socket

ノート

と をインストールMongoStorepassport.socket.io npm'sました。ログインして、ログインしているユーザーの を設定できますcookie( connect.sid)


質問

socketセッションを保存し、それらをユーザーの と結合するようにシステムをセットアップするにはどうすればよいsessionですか?


コード

app.js

  /* The usual express setup */
  passport = require('passport'),
  LocalStrategy = require('passport-local').Strategy,
  User = require('./models/user.js'),
  MongoStore = require('connect-mongo')(express);

app.use(express.cookieParser());
  app.use(express.bodyParser());
  app.use(express.session({
    secret: 'chuck norris', 
    store: new MongoStore({db: User.name}, // the db's name
        function(err) {
          console.log(err || 'connect ok!');
        })
  }));
  app.use(express.methodOverride());
  app.use(passport.initialize());
  app.use(passport.session());
  app.use(app.router);

app.js (パスポート部分)

passport.use(new LocalStrategy({
    usernameField: 'username',
    passwordField: 'password'
  },
  function(username, password, done) {
    User.findOne({username: username}, function(err, user) {
      if(!user) {
        return done(null, false, {message: 'Incorrect Username!'});
      }
      if(!user.validPassword(password)) {
        return done(null, false, {message: 'Incorrect Password!'});
      }
      return done(null, user);
    });
  }
));


passport.serializeUser(function(user, done) {
  done(null, user.id);
});

passport.deserializeUser(function(id, done) {
  User.findById(id, function(err, user) {
    done(err, user);
  });
});

app.post('/',
  passport.authenticate('local'),
    function(req, res) {
      res.redirect('/home/'+req.user.username);
    });

app.js (socket.io部分)

io.set('authorization', passportSocket.authorize({
  key: 'connect.sid',
  secret: 'chuck norris',
  store: /* Not entirely sure what goes here */
  fail : function(data, accept) { accept(null, false); },
  success: function(data, accept) { accept(null, true); }
}));


io.sockets.on('connection', function(socket) {
  console.log('User Connected: ' + socket.handshake.user.username);
});
4

1 に答える 1

10

新しいメモリ ストーリー オブジェクトのインスタンスを変数に格納し、それをエクスプレス IO とソケット IO の両方に渡します。(異なるストアを使用していることに注意してください。ただし、適切な方法で制御を渡す限り、理論的にはどのストアを使用してもかまいません)...

var ...
,MemoryStore = express.session.MemoryStore
,sessionStore = new MemoryStore();

次に app.configure で...

app.use(express.session({store:sessionStore,secret:'secret',key:'express.sid'}));

そして最後に socket.io configure で

io.configure(function (){
io.set("authorization", passportSocketIo.authorize({
    key:    'express.sid',       //the cookie where express (or connect) stores its session id.
    secret: 'secret', //the session secret to parse the cookie
    store:   sessionStore,     //the session store that express uses
    fail: function(data, accept) {
        // console.log("failed");
        // console.log(data);// *optional* callbacks on success or fail
        accept(null, false);             // second param takes boolean on whether or not to allow handshake
    },
    success: function(data, accept) {
      //  console.log("success socket.io auth");
     //   console.log(data);
        accept(null, true);
    }
}));

これを正しく行い、ユーザーの認証に成功した場合は、ハンドシェイク オブジェクトのセッション データにアクセスできるはずです。

console.log(socket.handshake.user.username);
//or sometimes it might be...
console.log(socket.handshake.user[0].username);

それが役立つことを願っています。

于 2013-02-28T00:31:08.133 に答える