首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Passport.js推特身份验证导致500错误,req.session未定义

Passport.js推特身份验证导致500错误,req.session未定义
EN

Stack Overflow用户
提问于 2013-12-02 16:46:29
回答 1查看 1.9K关注 0票数 1

我正在尝试使用passport-twitter在Node应用程序中设置会话,这样我就可以持久化用户数据,但据我所知,我无法打开会话支持。此外,我还确保回调函数与Twitter开发人员上的应用程序条目相匹配。程序抛出的500错误是:

代码语言:javascript
复制
500 Error: OAuthStrategy requires session support. Did you forget app.use(express.session(...))?**
    at Strategy.OAuthStrategy.authenticate (/Users/xxxxxxxx/web/Node/on/node_modules/passport-twitter/node_modules/passport-oauth1/lib/strategy.js:120:41)
    at Strategy.authenticate (/Users/xxxxxxxx/web/Node/on/node_modules/passport-twitter/lib/strategy.js:85:40)
    ....

当我检查第120行的strategy.js时,它说:

代码语言:javascript
复制
if (!req.session) { return this.error(new Error('OAuthStrategy requires session support. Did you forget app.use(express.session(...))?')); }

所以,很明显,req.session是未定义的。然而,我想我已经完成了让会话支持工作所需的所有工作。下面是我的主服务器js文件的大部分:

代码语言:javascript
复制
var express = require('express'),
app = express();

var http = require('http'),
https = require('https');

var mongodb = require('mongodb'),
mongoose = require('mongoose');

var passport = require('passport'),
TwitterStrategy = require('passport-twitter').Strategy,
imon = require('./imon'),
routes = require('./routes')(app),
user = require('./models/user'),
group = require('./models/group'),
song = require('./models/song'),
album = require('./models/album'),
activity_item = require('./models/activity_item');

app.set('env', 'development');

console.log("app.get('env') =", app.get('env'));
console.log(app.get('env') === 'development');

// development only
if (app.get('env') === 'development') {
    app.set('views', __dirname + '/views');
    app.use(express.logger('dev'));
    app.use(express.bodyParser());
    app.use(express.methodOverride());
    app.use(express.cookieParser('secret'));
    app.use(express.cookieSession());
    app.use(passport.initialize());
    app.use(passport.session());
    app.use(app.router);
    app.use(express.errorHandler());
}

// production only
if (app.get('env') === 'production') {
  // TODO
}


// all environments


mongoose.connect('mongodb://localhost/test');
var db = mongoose.connection;
db.on('error', console.error.bind(console, 'connection error:'));
db.once('open', function callback () {
  console.log('Connected to DB');
});


passport.use(new TwitterStrategy({
    consumerKey: "0GOReNaXWXCTpf7OQgrg",
    consumerSecret: "0wA8yUBrXz3ivpTHcuBbKp3vGN2ODnOF7iFM9DB48Y",
    callbackURL: "http://127.0.0.1:8888/auth/twitter/callback"
  },
    function(token, tokenSecret, profile, done) {
        console.log("THis gets called?");
        function sanitizeImgURL(string){
            return string.replace("_normal", "");
        }

        console.log("profile: ", profile);
        process.nextTick(function(){
            User.find({account: {id: profile.id}}, function(err, user) {
                if(err){
                    return done(err);
                }
                if(!user){
                    return done(null, false, { message: 'Incorrect password.' });
                }
                else if(user){
                    done(null, user);
            }
            var newUser = new User(
                {account:
                    {provider: profile.provider,
                    id: profile.id},
                username: profile.username,
                displayName: profile.displayName,
                email: profile.email,
                image: sanitizeImgURL(profile._json.profile_image_url)
            });
            return done(null, newUser);
        });
    });
    }
));

passport.serializeUser(function(user, done) {
    console.log("SERIALIZE: ", user);
  done(null, user);
});

passport.deserializeUser(function(obj, done) {
    console.log("DESERIALIZE: ", obj);
  done(null, obj);
});


/**
 * Routes
 */

// Redirect the user to Twitter for authentication.  When complete, Twitter
// will redirect the user back to the application at
//   /auth/twitter/callback
app.get('/auth/twitter', passport.authenticate('twitter'));

// Twitter will redirect the user to this URL after approval.  Finish the
// authentication process by attempting to obtain an access token.  If
// access was granted, the user will be logged in.  Otherwise,
// authentication has failed.
app.get('/auth/twitter/callback',
  passport.authenticate('twitter', { successRedirect: '/static/index.html',
                                     failureRedirect: '/static/login.html' }));

..。有些路线。

代码语言:javascript
复制
app.listen(8888);
EN

回答 1

Stack Overflow用户

发布于 2013-12-04 07:41:48

我想通了;有两件事:

1.)connect-redis中断了会话,仍然不知道为什么,但删除它修复了我的问题后,我...

2.)...移动了我的“请求路由”行,它将app对象作为参数放在我的app.use语句之后。现在很有意义了,我把app对象传递给我的routes,然后再配置会话之类的东西。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20324089

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档