将koa-passport与koa-router结合起来(获取用户数据)

时间:2015-03-29 08:05:41

标签: mongodb passport.js koa

我创建了一个登录用户,如果用户是数据库中的新用户,则可以登录用户并存储用户。

然后将用户重定向到/,然后检查他们是否经过身份验证,请参阅下面的内容(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);
    }));

2 个答案:

答案 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