3

我正在尝试将 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);
};

然后我在网上搜索,发现路由器的另一篇文章,它转到serializeUserdone(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 示例并尝试使用session,但我发送的每个请求都会收到 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

4

0 回答 0