Passport.js github策略callback总是返回“TypeError:无法设置属性'用户'未定义的”

我一般都是新来的护照authentication,并且正在尝试使用github策略passport-github创build一个简单的Express应用程序。 我已经成功使用谷歌和叽叽喳喳策略下面的基本相同的代码,但每次我尝试合并github策略时,我得到一个500响应与此错误,每当我点击callback路线:

无法设置未定义的属性“用户”

 TypeError:无法设置未定义的属性'user'
     at /Users/dan/Repos/passport-github-portal/node_modules/passport-github/node_modules/passport-oauth/node_modules/passport/lib/passport/http/request.js:45:35
     (/Users/dan/Repos/passport-github-portal/node_modules/passport/lib/authenticator.js:267:43)
    在序列化(/ Users / pass / pass / passport /
    在/Users/dan/Repos/passport-github-portal/app.js:49:7
     (/Users/dan/Repos/passport-github-portal/node_modules/passport/lib/authenticator.js:284:9)
    在Authenticator.serializeUser(/Users/dan/Repos/passport-github-portal/node_modules/passport/lib/authenticator.js:289:5)
     IncomingMessage.req.login.req.logIn(/Users/dan/Repos/passport-github-portal/node_modules/passport-github/node_modules/passport-oauth/node_modules/passport/lib/passport/http/request.js: 43:29)
    在Strategy.strategy.success(/Users/dan/Repos/passport-github-portal/node_modules/passport/lib/middleware/authenticate.js:228:13)
     (/Users/dan/Repos/passport-github-portal/node_modules/passport-github/node_modules/passport-oauth/lib/passport-oauth/strategies/oauth2.js:133:18)
    在/Users/dan/Repos/passport-github-portal/app.js:25:9

我的app.js如下:

var express = require('express'); var path = require('path'); var favicon = require('serve-favicon'); var logger = require('morgan'); var cookieParser = require('cookie-parser'); var bodyParser = require('body-parser'); var passport = require('passport'); var session = require('express-session'); var routes = require('./routes/index'); var users = require('./routes/users'); var auth = require('./routes/auth'); var app = express(); var GithubStrategy = require('passport-github').Strategy; passport.use(new GithubStrategy({ clientID: process.env.GITHUB_CLIENT_ID, clientSecret: process.env.GITHUB_CLIENT_SECRET, callbackURL: 'http://localhost:3000/auth/github/callback' }, function(accessToken, refreshToken, profile, done) { process.nextTick(function() { done(null, profile); }); })); // view engine setup app.set('views', path.join(__dirname, 'views')); app.set('view engine', 'ejs'); // uncomment after placing your favicon in /public //app.use(favicon(__dirname + '/public/favicon.ico')); app.use(logger('dev')); app.use(bodyParser.json()); app.use(bodyParser.urlencoded({ extended: false })); app.use(cookieParser()); app.use(express.static(path.join(__dirname, 'public'))); app.use(session({ secret: 'wordswordswords' })); app.use(passport.initialize()); app.use(passport.session()); passport.serializeUser(function(user, done) { done(null, user.id); }); passport.deserializeUser(function(user, done) { done(null, user); }); app.use('/', routes); app.use('/users', users); app.use('/auth', auth); // catch 404 and forward to error handler app.use(function(req, res, next) { var err = new Error('Not Found'); err.status = 404; next(err); }); // error handlers // development error handler // will print stacktrace if (app.get('env') === 'development') { app.use(function(err, req, res, next) { res.status(err.status || 500); res.render('error', { message: err.message, error: err }); }); } // production error handler // no stacktraces leaked to user app.use(function(err, req, res, next) { res.status(err.status || 500); res.render('error', { message: err.message, error: {} }); }); module.exports = app; 

和我的/routes/auth.js:

 var express = require('express'); var passport = require('passport'); var router = express.Router(); router.route('/github/callback') .get(passport.authenticate('github', { failureRedirect: '/error' }), function(req, res) { res.redirect('/users'); }); router.route('/github') .get(passport.authenticate('github')); module.exports = router; 

在以前的项目中,我在同一个应用程序中同时实施了google和twitter策略,但是当我尝试添加passport-github时,它打破了所有三种策略,给了我完全相同的“不能设置属性”用户的未定义错误每当我打三个callback路线中的任何一个。

任何帮助将不胜感激!

这看起来像一个兼容性问题,为快速修复设置护照版本:

 "passport": "0.2.2" 

长期的修复可能涉及更多的工作:更新你的代码,以便它能够与最新版本一起工作,和/或在repo中创build一个问题,或者发送一个带有修补程序的PR(如果你可以在这个部分上向后兼容)。

我们如何猜测这是问题?:在没有与authentication相关的变化时,testing开始失败+ packages.json中的stacktrace +“latest”

这个问题在Github上