Everyauth.js在第一次验证请求时失败

时间:2012-10-03 18:15:16

标签: node.js nginx express everyauth

背景:我使用nginx作为我的快速服务器的反向代理来处理SSL。我使用everyauth包来处理facebook oauth。 Redis用于会话商店。

问题:在第一个身份验证请求中,everyauth将在getAccessToken身份验证步骤超时。在第二个auth请求中,它将完成所有auth步骤并返回。

具体:我已经执行了getAccessToken步骤中everyauth使用 request 包的执行情况。 请求使用https模块发出永不返回的请求(永远不会执行回调)。

代码

var express = require('express')
  , RedisStore = require('connect-redis')(express)
  , everyauth = require('everyauth')
  , Promise = everyauth.Promise
  , app = express.createServer()
  , authConfig = require('./auth_config');

// Configure server to allow reverse proxy (nginx) to handle SSL requests
app.enable('trust proxy');
app.set('env', process.env.npm_package_config_env);

//everyauth config
everyauth.facebook
    .appId(authConfig.facebook.appId)
    .appSecret(authConfig.facebook.appSecret)
    .redirectPath(authConfig.facebook.redirectPath)
    .scope(authConfig.facebook.scope)
    .popup(true)
    .findOrCreateUser(function(session, accessToken, accessTokExtra, fbUserMetadata){
        ...
    });

app.configure(function(){
    // Check if behind secure reverse-proxy
    app.use(require('./middleware/secureProxyCheck')());
    app.set('views', __dirname + '/views');
    app.set('view engine', 'jade');
    app.use(express.bodyParser());
    app.use(express.methodOverride());
    app.use(express.cookieParser());
    app.use(express.session({
        secret: 'imnottelling', 
        store: new RedisStore({ host: "127.0.0.1", port: "6379" }),
        cookie: { secure: true }
    }));
    //WARNING: do not change the order of everyauth and router
    app.use(everyauth.middleware());
    app.use(app.router);
    app.use(require("./middleware/dynamicCacheHeaders")("sha256"));
});

/*app.get app.listen beyond this point*/

版本

  • 节点:0.8.8
  • 快递:2.5.10
  • connect-redis:1.4.4
  • Everyauth:0.3.0

1 个答案:

答案 0 :(得分:0)

此问题实际上与上述任何内容无关。问题是因为我没有仔细阅读daemon.node上的文档。第一次没有任何作用,因为它们都与前一个节点不再运行的进程相关联。难以调试但很容易修复(阅读文档)。