2

Twitterアカウントでログインできるnode.jsでアプリケーションを構築しています。

コードを初めて実行したときはうまくいきましたが、数日後にはエラーが返されるだけです。

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を使用しています

それで、それを修正するにはどうすればよいですか?

4

1 に答える 1

-2

これが本当にあなたのコードであり、ここに投稿する前に置き換えたものではない場合、Twitter またはクライアント (どちらかは忘れました) に、ログイン後の GET 呼び出しの代わりに自分自身を呼び出すように指示していることになります。

callbackURL : "http://127.0.0.1:7777/auth/twitter/callback"
于 2014-02-09T16:49:51.607 に答える