使用twitter oAuth和Passport.js登录

时间:2014-02-09 16:35:25

标签: node.js twitter-oauth passport.js passport-twitter

我正在node.js中构建一个允许使用Twitter帐户登录的应用程序。

我第一次运行代码时,机智起作用,但几天后它只会返回一些错误。

我尝试更改我的Twitter应用程序配置,但它不起作用。

app.js:

var express = require('express')
  , io
  , _appS = require('./appServer')
  , passport = require('passport')
  , TwitterStrategy = require('passport-twitter').Strategy
  ;

var app = express()
  , PORT = 7777
  ;


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

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

passport.use(new TwitterStrategy ({
        consumerKey : "consumer",
        consumerSecret : "secret",
        callbackURL : "http://127.0.0.1:7777/auth/twitter/callback"
    },
    function ( token, tokenSecret, profile, done ) {

        process.nextTick (function () {
            return done ( null, profile );
        });
    }
));

app.configure(function () {
    app.set('views', __dirname + '/views');
    app.set('view engine', 'jade');

    app.use(express.static(__dirname + '/static'));
    app.use(express.logger());
    app.use(express.cookieParser());
    app.use(express.bodyParser());
    app.use(express.methodOverride());
    app.use(express.session({secret : 'argentina campeon'}));
    app.use(passport.initialize());
    app.use(passport.session());
    app.use(app.router);

    app.engine('jade', require('jade').__express);
});

io = require('socket.io').listen(app.listen(PORT));

/**
 * ROUTES
 */

app.get(
    "/", 
    function ( req, res ) {
    if ( req.user ) {
        //hay usuario
        io.sockets.on('connection', function ( socket ) {
            _appS.init( req.user.id, socket );
        });

    }
        else
            res.redirect('/login');
    }
);

app.get(
    "/login", 
    function ( req, res ) {
        if ( ! req.user )
            res.render("login");
        else
            res.redirect('/');
    }
);

app.get(
    "/auth/twitter", 
    passport.authenticate('twitter'),
    function ( req, res ) { }
);

app.get(
    "/auth/twitter/callback", 
    passport.authenticate('twitter', { failureRedirect : '/login' }),
    function ( req, res ) {
        console.log( req.user );
        res.redirect('/');
    }
);

app.get(
    "/logout", 
    function ( req, res ) {
        req.logout();
        res.redirect('/');
    }
);

当我尝试登录时,它会将我重定向到twitter以验证应用程序权限,但它说:

  

我们正在将您重定向到该应用程序。这可能需要一些   分钟。

所以,如果我等待几秒钟,会出现一个新链接:

  

如果您的浏览器没有重定向您,请点击此处

所以,当我点击它时,它现在将我重定向到我的应用程序,但现在我收到一个错误:

Error: Failed to find request token in session at Strategy.OAuthStrategy.authenticate (C:\Program Files\nodejs\node_modules\passport-twitter\node_modules\passport-oauth1\lib\strategy.js:142:54) at Strategy.authenticate (C:\Program Files\nodejs\node_modules\passport-twitter\lib\strategy.js:85:40) at attempt (C:\Program Files\nodejs\node_modules\passport\lib\middleware\authenticate.js:337:16) at authenticate (C:\Program Files\nodejs\node_modules\passport\lib\middleware\authenticate.js:338:7) at callbacks (C:\Program Files\nodejs\node_modules\express\lib\router\index.js:164:37) at param (C:\Program Files\nodejs\node_modules\express\lib\router\index.js:138:11) at pass (C:\Program Files\nodejs\node_modules\express\lib\router\index.js:145:5) at Router._dispatch (C:\Program Files\nodejs\node_modules\express\lib\router\index.js:173:5) at Object.router (C:\Program Files\nodejs\node_modules\express\lib\router\index.js:33:10) at next (C:\Program Files\nodejs\node_modules\express\node_modules\connect\lib\proto.js:193:15)

有趣的是,在我的控制台中,我可以在登录后看到Twitter上的所有用户数据,因为在我的部分代码中我放了if ( req.user ) console.log( req.user );

  • 我使用的是最新版本的node.js及其软件包(express,passport,twitter-passport,socket.io)
  • 我正在使用Windows 7

那么,我该怎么做才能解决它?

1 个答案:

答案 0 :(得分:-2)

如果这真的是你的代码,而不是你在发布之前替换的东西,那么你告诉Twitter或客户端(我忘记了哪个)来调用本身而不是你的登录后GET电话:

callbackURL : "http://127.0.0.1:7777/auth/twitter/callback"