我正在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 );
那么,我该怎么做才能解决它?
答案 0 :(得分:-2)
如果这真的是你的代码,而不是你在发布之前替换的东西,那么你告诉Twitter或客户端(我忘记了哪个)来调用本身而不是你的登录后GET电话:
callbackURL : "http://127.0.0.1:7777/auth/twitter/callback"