【问题标题】:Not saving session on passport express server不在护照快递服务器上保存会话
【发布时间】:2017-09-18 14:11:12
【问题描述】:

将 node.js 与 express 服务器一起使用,我的目的是在会话中保存已登录的本地用户,以便我可以从前端调用它并在用户实际登录时获取用户信息。

为此,我正在使用快速会话和护照。如果正确登录并将会话保存在 req 中,以下代码将返回用户。

我已调试查询并正确返回数据。

passport.use('local-login', new LocalStrategy({
  usernameField: 'email',
  passwordField: 'pass',
  passReqToCallback: true
},
function(req, email, pass, done) {

 return modelUsers.login(email, pass, done);

}));

这是我的会话配置。

 app.use(session({
  resave: true,
  saveUninitialized: true,
  secret: 'strongertogether',
  cookie: { secure: false }
 } )); // session secret
app.use(passport.initialize());
app.use(passport.session());   // Persistent login sessions
app.use(cors());               //Required for signin facebook

据我所知,一旦登录完成,用户就会保存在会话中,并且函数 req.isAuthenticated() 应该返回一个真值,但它是假的,req.user 是未定义的.

事实 twitter 和 facebook 会话正常工作。

从我调用的前端(Angular.js)

app.get('/api/loggedin', usersController.loggedin);

那就去

function loggedin(req, res) {
 res.send(req.isAuthenticated() ? req.user : '0');
}

版本:

“快递”:“^4.9.3”

“快速会话”:“^1.11.3”

“本地护照”:“^1.0.0”

“护照”:“^0.2.2”

【问题讨论】:

  • 我没有仔细阅读您的代码,但我的这个苏格兰威士忌有助于理解您的问题https://scotch.io/tutorials/easy-node-authentication-setup-and-local。我正在使用相同的方法并且对我来说工作得很好。浏览链接可能我使用的东西丢失了。

标签: node.js session express passport-local passport.js


【解决方案1】:

您是否阅读过护照本地文件?

passport-local npm

您是否在您的路线中使用了类似 sn-ps 的路线?

app.post('/login', 
  passport.authenticate('local', { failureRedirect: '/login' }),
   function(req, res) {
  res.redirect('/');
});

您可以在本地护照文件中找到上面的代码。

或者你可以试试看这里:https://github.com/egin10/login-passport/blob/master/routes/users.js

【讨论】:

    猜你喜欢
    • 2013-03-09
    • 2017-09-30
    • 2018-10-24
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2022-10-24
    • 2017-03-07
    • 2016-10-27
    相关资源
    最近更新 更多