6
目標私が何をしたいのかセッションはpassport.js
:
- はソケット用のセッションを作成し、ユーザー
- のためのセッションを作成します(
socket.io
) passport.js
を使用して、ログインセッションとsocket
セッションを認証します。私はMongoStore
とpassport.socket.io npm's
をインストールしている
ノート
。私は質問
Iユーザーのsession
と
socket
セッションやカップルにそれらを格納するためのセットアップシステムにはどうすればよい
(connect.sid
)にログインしたユーザのcookie
にログインし、設定することができますか?
コード
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);
});
ありがとうございました。もう1つ、サーバーが再起動されると、ユーザーセッションが削除され、ページがログイン画面に戻ります。 – ashley
もう1つ言うことは、あなたのセッションが削除されてログインに戻る理由に私が答える必要があるということですか? –
私はそれが正しい行動だと思います。サーバーを再起動すると、新しいセッションがすべて開始されます。これは、再起動後に再認証し、認証後に新しいセッションIDが生成されるためです。サーバーの再起動後もセッションを維持したいと言っていますか? –