我正在尝试使用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