我创建了一个登录用户,如果用户是数据库中的新用户,则可以登录用户并存储用户。
然后将用户重定向到/
,然后检查他们是否经过身份验证,请参阅下面的内容(app.js):
.get('/', function* () {
if (this.isAuthenticated()) {
yield this.render('homeSecure', {}); // <-- need user data here
} else {
yield this.render('homePublic', {});
}
正如我在代码中评论的那样,我想发送已登录的用户对象。我不知道如何获取登录人员的id,因为koa的文档一般不是和快递一样完整。
我正在使用koa-generic-session-mongo
来处理我的会话。这是我的GoogleStrategy(auth.js):
var user = null;
// ...
var GoogleStrategy = require('passport-google').Strategy;
passport.use(new GoogleStrategy({
returnURL: 'http://localhost:' + (process.env.PORT || 3000) + '/auth/google/callback',
realm: 'http://localhost:' + (process.env.PORT || 3000)
},
function (identifier, profile, done) {
var emails = new Array();
for (var i = 0; i < profile.emails.length; i++) {
emails.push(profile.emails[i].value);
}
co(function* () {
yield users.findOne({
emails: emails
});
});
if (user === null) { // first time signin, create account
co(function* () {
user = {
id: 1,
name: profile.displayName,
emails: emails
};
yield users.insert(user);
});
}
console.log(user);
done(null, user);
}));
答案 0 :(得分:1)
publicRouter
.get('/', function* () {
if (this.isAuthenticated()) {
yield this.render('homeSecure', {
user: this.req.user
});
} else {
yield this.render('homePublic', {});
}
})...
答案 1 :(得分:0)
免责声明:我没有使用过koa-passport,我只是查看了代码。
根据the source code of the koa-passport library,您正在寻找的属性为passport.user
,并按照以下方式使用:
app.use( function*(){
var user = this.passport.user
})
因此,您的代码示例将变为
.get('/', function* () {
if (this.isAuthenticated()) {
yield this.render('homeSecure', this.passport.user );
} else {
yield this.render('homePublic', {});
}
如果这不起作用,this file会让我怀疑koa-passport遵循标准护照界面,并为请求提供this.user
。