获取 Passport.js 中的当前用户

3
我有一个 Express.js 文件,如下所示:
var express = require('express');
var favicon = require('serve-favicon');
var morgan = require('morgan');
var compression = require('compression');
var bodyParser = require('body-parser');
var methodOverride = require('method-override');
var cookieParser = require('cookie-parser');
var errorHandler = require('errorhandler');
var path = require('path');
var config = require('./environment');
var passport = require('passport');

module.exports = function(app) {
    var env = app.get('env');

    app.set('views', config.root + '/server/views');
    app.engine('html', require('ejs').renderFile);
    app.set('view engine', 'html');
    app.use(compression());
    app.use(bodyParser.urlencoded({
        extended: false
    }));
    app.use(bodyParser.json());
    app.use(methodOverride());
    app.use(cookieParser());
    app.use(passport.initialize());
    app.use(passport.session()); // passport session middleware 
    if ('production' === env) {
        app.use(favicon(path.join(config.root, 'public', 'favicon.ico')));
        app.use(express.static(path.join(config.root, 'public')));
        app.set('appPath', config.root + '/public');
        app.use(morgan('dev'));
    }

    if ('development' === env || 'test' === env) {
        app.use(require('connect-livereload')());
        app.use(express.static(path.join(config.root, '.tmp')));
        app.use(express.static(path.join(config.root, 'client')));
        app.set('appPath', 'client');
        app.use(morgan('dev'));
        app.use(errorHandler()); // Error handler - has to be last
    }
};

当用户使用Facebook登录后,在我的控制器中,当我尝试执行req.userreq.session.passport.user时,会返回undefined

如何获取当前已登录的用户?


这段代码不足够。 - NeiL
2
请添加 passport.serializeUserpassport.deserializeUserpassport.use() 调用。另外,如果上述是您完整的 Express 应用程序配置,则没有会话支持。在调用 passport.session() 之前安装 express-session 并使用它。 - vesse
2个回答

13

当认证成功时,req.user 会自动设置为用户。

var express               = require("express"),
app                   = express(),
bodyParser            = require("body-parser"),
mongoose               = require("mongoose"),
passport              = require("passport"),
flash                 = require("connect-flash"),
localStrategy         = require("passport-local"),
User                  = require("./models/user"),
passportLocalMongoose = require("passport-local-mongoose")


app.use(require("express-session")({
secret: "demoapp",
resave: false,
saveUninitialized: false
}));

app.use(passport.initialize());
app.use(passport.session());

passport.use(new localStrategy(User.authenticate()));
passport.serializeUser(User.serializeUser());
passport.deserializeUser(User.deserializeUser());

app.use(bodyParser.urlencoded({extended: true}));

app.set("view engine", "ejs")
app.use(express.static(__dirname + "/public"));
app.use(express.static(__dirname + "/dashboard"));

获取当前用户的详细信息。您可以将currentUser设置为您自己的文本

app.use(function(req,res,next){
  res.locals.currentUser = req.user;
  next();
})

如果您正在使用ejs,请在浏览器中显示用户个人资料

<p> <%= currentUser.username %> </p>
<p> <%= currentUser.country %> </p>

0

您需要定义认证策略并调用passport.authenticate来对用户进行身份验证。 在passport指南中可以看到一个示例。


我能够进行身份验证和登录。当我转到主页时,它会发出大量调用来获取数据并存储一些信息。要存储信息,我需要用户信息。 - harshit
@harshit - 你发布了完整的代码吗?你实现了护照序列化功能吗? - drorw
是的,我忘记添加护照序列化功能了。 - harshit

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接