为什么我的koa-passport身份验证参数用户总是未定义?

时间:2017-04-20 04:43:05

标签: node.js session passport.js koa2 koa-passport

我正在尝试使用koa-passport作为koa2,并按照作者的例子,但我总是得到“未经授权”。我使用了console.log,发现它甚至点击 serializeUser

var UserLogin = async (ctx, next) =>{
    return passport.authenticate('local', function(err, user, info, status) {
        if (user === false) {
            ctx.body = { success: false }
        } else {
            ctx.body = { success: true }
            return ctx.login(user)
        }
    })(ctx, next);
};

然后我在网上搜索并发现另一个路由器的写法,它转到 serializeUser ,但是 done(null,user.id)引发了错误“ 无法从未定义获取ID。

let middleware = passport.authenticate('local', async(user, info) => {
        if (user === false) {
            ctx.status = 401;
        } else {
          await ctx.login(ctx.user, function(err){
              console.log("Error:\n- " + err);
          })
          ctx.body = { user: user }
        }
      });
    await middleware.call(this, ctx, next)

auth.js如下所示。此外,我在此处跟koa-passport example from the author并尝试使用会话,但我发送的每个请求都会收到一个TypeError,表示“无法读取属性'消息'未定义”。但我认为这不是身份验证的核心问题,但如果确实如此,请参考。

const passport = require('koa-passport')
const fetchUser = (() => {
  const user = { id: 1, username: 'name', password: 'pass', isAdmin: 'false' };
  return async function() {
    return user
  }
})()

const LocalStrategy = require('passport-local').Strategy
passport.use(new LocalStrategy(function(username, password, done) {
  fetchUser()
    .then(user => {
      if (username === user.username && password === user.password) {
          done(null, user)
      } else {
        done(null, false)
      }
    })
    .catch(err => done(err))
}))

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

passport.deserializeUser(async function(id, done) {
  try {
    const user = await fetchUser();
    done(null, user)
  } catch(err) {
    done(err)
  }
})

module.exports = passport;

顺便说一句,当我使用简单的默认值时,它只会给我一个“未找到”。但是通过console.log我可以看到它实际进入 loginPass

var loginPass = async (ctx, next) =>{
    passport.authenticate('local', {
        successRedirect: '/myApp',
        failureRedirect: '/'
    });
};

在server.js中:

// Sessions
const convert = require('koa-convert'); 
const session = require('koa-generic-session');
app.keys = ['mySecret'];
app.use(convert(session()));

// authentication
passport = require('./auth');
app.use(passport.initialize());
app.use(passport.session());

非常感谢任何帮助! :d

0 个答案:

没有答案