使用 GitHub 策略时 Passport req.user 未定义 [英] Passport req.user is undefined when using GitHub strategy

查看:53
本文介绍了使用 GitHub 策略时 Passport req.user 未定义的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试使用通行证设置 Github 身份验证.

I'm trying to set up Github authentication using passport.

app.js(我设置中间件的地方)

var createError = require('http-errors');
var express = require('express');
var path = require('path');
var cookieParser = require('cookie-parser');
var logger = require('morgan');

const session = require('express-session');
const passport = require('passport');
const GitHubStrategy = require('passport-github').Strategy;


var indexRouter = require('./routes/index');

var app = express();
const helmet = require('helmet');

app.use(helmet());


const passportConfig = require('./config');

//================================PASSPORT CONFIG=======================    
app.use(session({
    secret: 'test1234',
    resave: false,
    saveUninitialized: true,
    cookie: { secure: true }
}));

app.use(passport.initialize());
app.use(passport.session());
passport.use(new GitHubStrategy(passportConfig,
    function (accessToken, refreshToken, profile, cb) {
        return cb(null, profile)
    }
));

passport.serializeUser(function(user, done) {
    done(null, user.id);
});

passport.deserializeUser(function(id, done) {
    done(null, user);
});

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');

app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({extended: false}));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

app.use('/', indexRouter);

// catch 404 and forward to error handler
app.use(function (req, res, next) {
    next(createError(404));
});

// error handler
app.use(function (err, req, res, next) {
    // set locals, only providing error in development
    res.locals.message = err.message;
    res.locals.error = req.app.get('env') === 'development' ? err : {};

    // render the error page
    res.status(err.status || 500);
    res.render('error');
});

module.exports = app;

如您所见,我设置了快速会话并使用了passport.initialize() 和passport.session()

As you can see, I set up express session and use passport.initialize() and passport.session()

但是当我尝试在我的任何路由中检索 req.user 对象时,它返回未定义.有谁知道这可能是什么原因?

But when i try retrieving the req.user object in any of my routes, it returns undefined. Does anyone know what the reason for this might be?

推荐答案

我觉得这是app.use(passport.session());中间件的问题,在做之前手动保存会话任何动作.

I think this is an issue of app.use(passport.session()); middleware, Manually saving the session before doing any action.

app.get('slack/callback', function(req,res){
    passport.authorize('slack');
    //Manually save session before redirect.
    req.session.save(function(){
        res.redirect('/someURL');
    });
})

这篇关于使用 GitHub 策略时 Passport req.user 未定义的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆